Chrome 54 Beta:媒體平臺等多項內(nèi)容改進
Chrome 54 Beta版本有幾項進行了優(yōu)化,包括自定義元素 V1、BroadcastChannel 和媒體平臺改進等。
自定義元素 v1
復(fù)雜的用戶界面通常需要大量 HTML。大多數(shù)語言可讓開發(fā)者在語言原語的基礎(chǔ)上創(chuàng)建自己的組件,以緩解這種繁冗。自定義元素可讓開發(fā)者創(chuàng)建自定義的 HTML 標記,以及在 JavaScript 中定義新元素的 API 和行為。這樣可以使用瀏覽器原生的方式構(gòu)建可重復(fù)使用、可互操作的組件。
Chrome 54 支持***的自定義元素 V1 規(guī)范,該規(guī)范獲得了主要瀏覽器供應(yīng)商的廣泛認同。Chrome 也會繼續(xù)支持 V0 API,直到有足夠的開發(fā)者轉(zhuǎn)移到 V1。
BroadcastChannel
桌面用戶同時打開多個窗口或選項卡是很常見的事。有些網(wǎng)站利用了此行為,例如網(wǎng)頁編輯器可在其自己的選項卡中打開文檔。在歷史上,這些選項卡之間的通信一直很難。BroadcastChannel 是窗口、選項卡、iframe、Web Worker 及服務(wù)工作線程之間一種新型的一對多消息傳遞 API。它可讓腳本建立命名通道以在同源瀏覽上下文之間發(fā)送消息。
Chrome(Android 版)的媒體平臺改進
對于需要靈活利用整個屏幕的移動設(shè)備,媒體在瀏覽體驗中的角色越來越吃重。現(xiàn)在,當(dāng)屏幕方向改變后,除了用戶手勢,開發(fā)者還可以使用 Element.requestFullScreen() 觸發(fā)全屏模式。這可以提供像媒體播放器旋轉(zhuǎn)切換至全屏這樣的體驗。
除了對全屏模式的改進之外,Android 上的 Chrome 現(xiàn)在可對后臺運行的 HTMLVideoElement 保持提供媒體通知,可讓用戶在視頻不可見時繼續(xù)播放視頻。開發(fā)者可以使用Page Visibility API 檢測后臺視頻播放。
此版本中的其他特性
- 在卸載處理程序中發(fā)起的導(dǎo)航將被阻止,任何之前的導(dǎo)航將會繼續(xù)。
- CanvasRenderingContext2D 的 imageSmoothingQuality 屬性可讓開發(fā)者在縮放時調(diào)整分辨率來平衡性能與圖像質(zhì)量。
- 網(wǎng)站可以使用 Node.getRootNode(options) 獲取指定節(jié)點的根。
- 利用 PushSubscription.options,網(wǎng)站可以跟蹤 applicationServerKeys,而無需離線存儲它們。
- Resource Timing API 現(xiàn)在支持 transfer、encoded 和 decoded 大小屬性,可讓開發(fā)者測量緩存***率和字節(jié)使用量。
- user-select 屬性可讓開發(fā)者指定用戶可以選擇哪些元素以及如何選擇。
- Foreign Fetch 和 WebUSB 可供試驗用作起源試驗。
棄用和互操作性的改善
- 為了匹配其他瀏覽器中的行為,嵌入的 YouTube Flash 播放器將被 Chrome 覆蓋,以使用 HTML5 嵌入的樣式,改進 Chrome Desktop 上的性能和安全。
- CacheQueryOptions 現(xiàn)在符合所有 CacheStorage 方法中的規(guī)范。
- initTouchEvent 已移除,代之以 新的 TouchEvent() 構(gòu)造函數(shù)。
- SVGZoomEvent 已移除,因為它不再屬于 SVG 2.0 規(guī)范。
- SVGSVGElement.currentView、SVGSVGElement.useCurrentView、SVGViewSpec 接口和 SVGSVGElement.viewport 已移除,因為它們不再屬于 SVG 2.0 規(guī)范。
- SVGTests.requiredFeatures 屬性已棄用,因為它不再在 SVG 2.0 規(guī)范中提供有用的功能。
- SVGElement 現(xiàn)在支持 dataset 屬性。
- KeyEvent.keyIdentifier 字段已移除,代之以 KeyboardEvent.key 字段。
- window.external.IsSearchProviderInstalled() 和 AddSearchProvider() 現(xiàn)已棄用,因為大多數(shù)其他瀏覽器不再支持它們。