close

最近 Chrome 剛剛發布了 100 版本,我們來看看有哪些我們需要注意的點?

三位數的版本號

記得 Chrome 在很久以前第一次達到版本號 10 時,隨着主要版本號從一位數變為兩位數,很多 User-Agent 解析庫發生了很多問題。現在 Chrome 和 Firefox 都馬上要突破 100 版本了,Edge 也不甘落後,我們可能需要提前注意一下三位數版本號可能會帶來的相關問題,以便在它真的升上去的時候做好準備。

這裡舉幾個可能出問題的場景:

從 userAgent 取到的瀏覽器版本號為字符串,你直接用字符串去比較版本大小:

varbrowser_version="100";varsupport_min_version="90";if(browser_version<support_min_version){console.log("tooold");}else{console.log("supported");}

這個在 版本<100 的時候是沒啥問題的,但是一旦突破 100,比較可能就亂了:

比較好的做法是先將字符串轉成整數:

varbrowser_version=parseInt("100",10)varsupport_min_version=90;if(browser_version<support_min_version){console.log("tooold");}else{console.log("supported");}

另外還有個比較常見的問題,代碼里如果用正則匹配 UA 中的瀏覽器版本,可能寫死了兩位數:

constua_string="Mozilla/5.0(Macintosh;IntelMacOSX10.15;rv:91.0)Gecko/20100101Firefox/91.0";constua_100="Mozilla/5.0(Macintosh;IntelMacOSX10.15;rv:100.0)Gecko/20100101Firefox/100.0";ua_string.match(/Firefox\/(\d\d)/);//["Firefox/91","91"]ua_string.match(/Firefox\/(\d{2})/);//["Firefox/91","91"]ua_string.match(/Firefox\/(\d\d)\./);//["Firefox/91.","91"]ua_100.match(/Firefox\/(\d\d)/);//["Firefox/10","10"]ua_100.match(/Firefox\/(\d{2})/);//["Firefox/10","10"]ua_100.match(/Firefox\/(\d\d)\./);//null

更好的做法是不應該限制數字位數:

ua_string.match(/Firefox\/(\d+)/);//["Firefox/91","91"]ua_string.match(/Firefox\/(\d+)/);//["Firefox/100","100"]

我在去年就分析過這個問題了,現在還沒注意到的,要認真看看這個了 👉 Chrome 版本即將突破100 ?這個問題不容忽視!

100CoolWebMoments

1989 年 3 月 12 日,在瑞士的歐洲核子研究中心工作的蒂姆·伯納斯-李向他的老闆遞交了一篇題目為「Information Management: A Proposal」的建議書。後來人們把這一天當作萬維網 (WWW, World Wide Web) 誕生的日子。一晃三十年過去,web 早已成為這個世界重要的組成部分。

在 Chrome 100 版本發布的日子,Google 發布了 Web 100 個令人激動的瞬間 (https://developer.chrome.com/100/),同時也在推特上發起了 #100CoolWebMoments 活動。

這個我也總結過了,感興趣 👉 100個Web令人激動的時刻

簡化的 User-Agent

Chrome 100 將是最後一個默認支持未刪減的 User-Agent 字符串的版本。Chrome 推薦大家用新的 User-Agent Client Hints API 替換 User-Agent 字符串。

從 Chrome 101 開始, User-Agent 將逐漸減少。

這個問題我之前也講過了,👉 Chrome:聽說你們濫用 UA? 廢了它!

多屏窗口放置API

對於某些應用程序,打開新的窗口並將它們放在特定位置或特定顯示器是一項很重要的功能。比如,我們在演示 PPT 的時候,我希望 PPT 在主顯示器上全屏顯示,而我們做的一些講稿的備註信息希望顯示在另一個顯示器上。

Chrome 100 為我們帶來了新的 Multi-Screen Window Placement API,它可以把連接到用戶機器的顯示器枚舉出來,並將窗口放置在特定屏幕上。

您可以通過 window.screen.isExtended 快速檢查是否有多個屏幕連接到設備:

constisExtended=window.screen.isExtended;//returnstrue/false

關鍵功能在 window.getScreenDetails() 中,它提供了有關附加顯示器的詳細信息。

constx=awaitwindow.getScreenDetails();//returns//{//currentScreen:{...}//oncurrentscreenchange:null//onscreenschange:null//screens:[{...},{...}]//}

比如,你可以確定哪個是主屏幕,然後用 requestFullscreen() 讓某些元素在該顯示器上全屏顯示。

try{constscreens=awaitwindow.getScreenDetails();constprimary=screens.filter((screen)=>screen.primary)[0]awaitelem.requestFullscreen({screen:primary});}catch(err){console.error(err);}

它還提供了一個事件監聽器,可以監聽到插入或移除新顯示器、分辨率變化等事件。

constscreens=awaitwindow.getScreenDetails();letnumScreens=screens.screens.length;screens.addEventListener('screenschange',(event)=>{if(screens.screens.length!==numScreens){console.log('Screencountchanged');numScreens=screens.screens.length;}});

另外,W3C 第二屏工作組(Second Screen Working Group 旨在開發有關規範以支持網頁使用輔助屏幕來顯示網頁內容)近期也更新了工作章程:

新章程將多屏窗口放置 API 納入標準化流程,該規範允許 Web 應用查詢其設備獲取直接連接的顯示器信息,並在特定屏幕上放置內容。

參考
https://www.youtube.com/watch?v=VK7oR5vLluk&t=65s
https://developer.chrome.com/blog/new-in-chrome-100/
https://web.dev/multi-screen-window-placement/
最後

如果你有任何想法,歡迎在留言區和我留言,如果這篇文章幫助到了你,歡迎點讚、在看和關注。你的點讚、在看和關注是對我最大的支持!

arrow
arrow
    全站熱搜
    創作者介紹
    創作者 鑽石舞台 的頭像
    鑽石舞台

    鑽石舞台

    鑽石舞台 發表在 痞客邦 留言(0) 人氣()