Chrome v80 發佈:針對 Worker 的 JS 模塊支持

做者:Tobias Uhlig

翻譯:瘋狂的技術宅前端

原文:https://medium.com/@tobiasuhl...git

未經容許嚴禁轉載程序員

Google 於 2020 年 2 月 4 日星期二發佈了 Chrome v80。我一直在等待這個特定版本的發佈,它是過去很長時間以來發布的最重要的主要版本。github

Chrome平臺狀態 www.chromestatus.com面試

什麼是 Javascript 模塊?

一旦使用 ES6+ 的類系統,你極可能會自動使用 JS 模塊:chrome

image.png

若是你堅持「每一個文件1個類」的設計模式,則極可能要導入擴展的基類。你也極可能但願在文件末尾導出新類。一旦使用 import 或 export 語句,你的文件就已經被視爲 JS 模塊。segmentfault

JS 模塊能夠直接在瀏覽器中運行嗎?

在主線程內部,這已經在 Chrome,Firefox 和 Safari 中成爲可能。在 Chrome 瀏覽器中使用 Web Worker 內部的 JS 模塊已經有至關長的一段時間了,可是隱藏在實驗性標記的後面。如今有了 Chrome v80,終於能夠直接使用了。設計模式

注:此舉會大大拉開 Chrome 與其餘瀏覽器之間的距離。遺憾的是,儘管 FF 和 Safari 開發團隊已經將此功能計劃公開了好幾年,可是優先級很低。瀏覽器

如何從 JS 模塊建立 worker?

這由你決定。若是你想將 js 模塊文件命名爲 .mjs.js,請添加類型:module 是實現此目的的關鍵。服務器

image.png

直接在瀏覽器內部使用 JS 模塊有什麼好處?

你能夠建立結構良好的程序,並在瀏覽器中運行它們,而無需任何與 JS 相關的構建過程。這意味着你能夠更改源代碼,而只是從新加載瀏覽器頁面,而無需 Webkit 監視文件更改和模塊的熱更換。

已經有一個由 Web Worker 驅動的 JS UI 框架了嗎?

是的,neo.mjs 於 2019 年 11 月 23 日向公衆發佈。

倉庫:

https://github.com/neomjs/neo

在線示例:

https://neomjs.github.io/pages/

接下來是什麼?

若是你查看了發佈時間表,可能已經注意到 Chrome v81 計劃於 3 月 17 日發佈。此版本將包括對共享 woker 的 JS 模塊支持。這是製做多瀏覽器窗口應用(例如能夠在多個屏幕上運行的應用程序)的關鍵。


本文首發微信公衆號:前端先鋒

歡迎掃描二維碼關注公衆號,天天都給你推送新鮮的前端技術文章

歡迎掃描二維碼關注公衆號,天天都給你推送新鮮的前端技術文章

歡迎繼續閱讀本專欄其它高贊文章:


相關文章
相關標籤/搜索