搜尋
首頁web前端H5教程HTML5 Web Worker的介紹(附範例)

HTML5 Web Worker的介紹(附範例)

Mar 15, 2019 pm 03:10 PM
html5javascript

這篇文章帶給大家的內容是關於HTML5 Web Worker的介紹(附範例),有一定的參考價值,有需要的朋友可以參考一下,希望對你有幫助。

瀏覽器中的Web Worker

背景介紹

我們都知道JavaScript這個語言在執行的時候是採用單執行緒執行的,也就是說在同一時間只能做一件事,這也和這門語言有很大的關係,採用同步執行的方式進行運行,如果出現阻塞,那麼後面的程式碼將不會執行,HTML5則提出了web Worker標準,表示JavaScript允許有多個線程,但是子線程完全受主線程的控制,子線程不能操作DOM,只有主線程可以操作DOM,所以以主線程為主的單線程執行原理成了JavaScript這門語言的核心。

進程與執行緒的差異

根本區別:進程是作業系統資源分配的基本單位,而執行緒是任務調度和執行的基本單位。
  在作業系統中能同時執行多個行程(程式);而在同一個行程(程式)中有多個執行緒同時執行。

相容性

HTML5 Web Worker的介紹(附範例)

web worker是什麼?

簡單來說,其實就是在Javascript單執行緒執行的基礎上,開啟一個子線程,進行程式處理,而不影響主執行緒的執行,當子執行緒執行完畢之後再回到主執行緒上,在這個過程中並不影響主執行緒的執行過程。

舉個栗子

傳統情況下,執行下面的程式碼後,整個頁面都會被凍結,由於javascript是單執行緒處理,如下程式碼已經完全組塞了後續的執行

while(1){}

如果換一種方式,我們透過開啟一個新的線程來執行這段程式碼,將他放在一個單獨的worker.js檔案中,在主執行緒執行以下程式碼,則可以避免這種情況。

var worker = new Worker("worker.js")

Web Worker的用法

判斷目前瀏覽器是否支援web worker

if (typeof (Worker) != "undefined") { //浏览器支持web worker  
    if (typeof (w) == "undefined") { //w是未定义的,还没有开始计数        
        w = new Worker("webworker.js"); //创建一个Worker对象,利用Worker的构造函数  
    }
    //onmessage是Worker对象的properties  
    w.onmessage = function (event) { //事件处理函数,用来处理后端的web worker传递过来的消息  
        // do something
    };
} 
else { // 浏览器不支持web worker
    // do something
}

API

①建立新的Worker

var worker = new Worker("worker.js")

②傳遞參數

worker.postMessage()

③接收訊息

worker.onMessage = function(msg){}

④異常處理

worker.onerror = function(err){}

⑤結束worker

worker.terminate()

⑥載入工具類別函數

importScripts()

Worker作用域

當我們創建一個新的worker時,該程式碼會運行在一個全新的javascript的環境中(WorkerGlobalScope)運行,是完全和創建worker的腳本隔離,這時我們可以吧創建新worker的腳本叫做主線程,而被創建的新的worker叫做子線程。
  WorkerGlobalScope是worker的全域對象,所以它包含所有核心javascript全域物件擁有的屬性如JSON等,window的一些屬性,也擁有類似XMLHttpRequest()等。
  但是我們所開啟的新的worker也就是子線程,並不支援操作頁面的DOM。

線程間的通訊是傳值而不是傳送地址

主執行緒與子執行緒資料通訊方式有多種,通訊內容,可以是文本,也可以是物件。需要注意的是,這種通訊是拷貝關係,也就是傳值而不是位址,子執行緒對通訊內容的修改,不會影響到主執行緒。事實上,瀏覽器內部的運作機制是,先將通訊內容串行化,然後把串列化後的字串寄給子線程,後者再將它還原。

JavaScript中的資料類型存放原理以及傳遞規則

HTML5 Web Worker的介紹(附範例)

#共享執行緒(SharedWorker)

共享執行緒是為了避免執行緒的重複建立和銷毀過程,降低了系統效能的消耗,
  共享執行緒SharedWorker可以同時有多個頁面的執行緒連結。
  使用SharedWorker建立共享線程,也需要提供一個javascript腳本檔案的URL位址或Blob,該腳本檔案中包含了我們在線程中需要執行的程式碼,如下:

var worker = new SharedWorker("sharedworker.js");

#共享線程也使用了message事件監聽執行緒訊息,但使用SharedWorker物件的port屬性與執行緒通訊如下:

worker.port.onmessage = function(msg){};

同時我們也可以使用SharedWorker物件的port屬性向共用執行緒傳送訊息如下:

worker.port.postMessage(msg);

运行原理

生命周期

①当一个web worker的文档列表不为空的时候,这个web worker会被称之为许可线程。
②当一个web worker的文档列表中的任何一个对象都是处于完全活动状态的时候,这个web worker会被称之为需要激活线程。
③当一个web worker是许可线程并且拥有计数器或者拥有数据库事务或者拥有网络连接或者它的web worker列表不为空的时候,这个web worker会被称之为受保护的线程。
④当一个web worker是一个非需要激活线程同时又是一个许可线程的时候,这个web worker会被称之为可挂起线程。

以webKit为例加载并执行worker的过程

HTML5 Web Worker的介紹(附範例)

应用

可以做什么:

1.可以加载一个JS进行大量的复杂计算而不挂起主进程,并通过postMessage,onmessage进行通信
2.可以在worker中通过importScripts(url)加载另外的脚本文件
3.可以使用 setTimeout(), clearTimeout(), setInterval(), and clearInterval()
4.可以使用XMLHttpRequest来发送请求
5.可以访问navigator的部分属性

不可以做什么:

1.不能跨域加载JS
2.worker内代码不能访问DOM
3.各个浏览器对Worker的实现不大一致,例如FF里允许worker中创建新的worker,而Chrome中就不行
4.不是每个浏览器都支持这个新特性

以上是HTML5 Web Worker的介紹(附範例)的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:segmentfault。如有侵權,請聯絡admin@php.cn刪除
H5:工具,框架和最佳實踐H5:工具,框架和最佳實踐Apr 11, 2025 am 12:11 AM

H5開發需要掌握的工具和框架包括Vue.js、React和Webpack。 1.Vue.js適用於構建用戶界面,支持組件化開發。 2.React通過虛擬DOM優化頁面渲染,適合複雜應用。 3.Webpack用於模塊打包,優化資源加載。

HTML5的遺產:當前了解H5HTML5的遺產:當前了解H5Apr 10, 2025 am 09:28 AM

HTML5hassignificantlytransformedwebdevelopmentbyintroducingsemanticelements,enhancingmultimediasupport,andimprovingperformance.1)ItmadewebsitesmoreaccessibleandSEO-friendlywithsemanticelementslike,,and.2)HTML5introducednativeandtags,eliminatingthenee

H5代碼:可訪問性和語義HTMLH5代碼:可訪問性和語義HTMLApr 09, 2025 am 12:05 AM

H5通過語義化元素和ARIA屬性提升網頁的可訪問性和SEO效果。 1.使用、、等元素組織內容結構,提高SEO。 2.ARIA屬性如aria-label增強可訪問性,輔助技術用戶可順利使用網頁。

H5與HTML5相同嗎?H5與HTML5相同嗎?Apr 08, 2025 am 12:16 AM

"h5"和"HTML5"在大多數情況下是相同的,但它們在某些特定場景下可能有不同的含義。 1."HTML5"是W3C定義的標準,包含新標籤和API。 2."h5"通常是HTML5的簡稱,但在移動開發中可能指基於HTML5的框架。理解這些區別有助於在項目中準確使用這些術語。

H5的功能是什麼?H5的功能是什麼?Apr 07, 2025 am 12:10 AM

H5,即HTML5,是HTML的第五個版本,它為開發者提供了更強大的工具集,使得創建複雜的網頁應用變得更加簡單。 H5的核心功能包括:1)元素允許在網頁上繪製圖形和動畫;2)語義化標籤如、等,使網頁結構清晰,利於SEO優化;3)新API如GeolocationAPI,支持基於位置的服務;4)跨瀏覽器兼容性需要通過兼容性測試和Polyfill庫來確保。

h5鏈接怎麼做h5鏈接怎麼做Apr 06, 2025 pm 12:39 PM

如何創建 H5 鏈接?確定鏈接目標:獲取 H5 頁面或應用程序的 URL。創建 HTML 錨點:使用 <a> 標記創建錨點並指定鏈接目標URL。設置鏈接屬性(可選):根據需要設置 target、title 和 onclick 屬性。添加到網頁:將 HTML 錨點代碼添加到希望鏈接出現的網頁中。

h5兼容問題怎麼解決h5兼容問題怎麼解決Apr 06, 2025 pm 12:36 PM

解決 H5 兼容問題的方法包括:使用響應式設計,允許網頁根據屏幕尺寸調整佈局。採用跨瀏覽器測試工具,在發布前測試兼容性。使用 Polyfill,為舊瀏覽器提供對新 API 的支持。遵循 Web 標準,使用有效的代碼和最佳實踐。使用 CSS 預處理器,簡化 CSS 代碼並提高可讀性。優化圖像,減小網頁大小並加快加載速度。啟用 HTTPS,確保網站的安全性。

h5怎么生成鏈接h5怎么生成鏈接Apr 06, 2025 pm 12:33 PM

h5頁面可以通過兩種方法生成鏈接:手動創建鏈接或使用短鏈接服務。通過手動創建,只需複制h5頁面的URL即可;通過短鏈接服務,需將URL粘貼到服務中,然後獲取縮短的URL。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
3 週前By尊渡假赌尊渡假赌尊渡假赌

熱工具

DVWA

DVWA

Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SAP NetWeaver Server Adapter for Eclipse

SAP NetWeaver Server Adapter for Eclipse

將Eclipse與SAP NetWeaver應用伺服器整合。

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

Dreamweaver Mac版

Dreamweaver Mac版

視覺化網頁開發工具

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境