成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

您的位置:首頁技術文章
文章詳情頁

如何使用JS中的webWorker

瀏覽:181日期:2024-03-26 10:44:45
目錄一、webWorker之初體驗二、webWorker之常用API1、postMessage(data)2、terminate()3、message4、error三、worker上下文四、關于worker一、webWorker之初體驗

所以,JavaScript是單線程也是有背景的。

如下:

<!DOCTYPE html> <head><title>singleThread</title><meta http-equiv='Content-Type' content='text/html; charset=utf-8'/> </head> <body><script> //添加到任務隊列中,待同步任務所處的‘執行棧’執行完畢,1秒后執行任務隊列中的這個匿名函數 setTimeout(function(){console.log(’come on’); },1000); //只要不關閉該alert,‘執行棧’就沒結束,從而也就不會進入到任務隊列中 alert(’waiting’);</script> </body></html>

但,HTML5引入了一個工作線程(webWorker)的概念。它允許開發人員編寫能夠長時間運行而不被用戶所中斷的后臺程序,去執行事務或者邏輯,并同時保證頁面對用戶的響應。

簡而言之,就是允許JavaScript創建多個線程,但是子線程完全受主線程控制,且不得操作DOM。

從而,可以用webWorker來處理一些比較耗時的計算。

如下,主頁面:

<!DOCTYPE html> <head><title>worker</title><meta http-equiv='Content-Type' content='text/html; charset=utf-8'/><script> function init(){//創建一個Worker對象,并向它傳遞將在新線程中執行的腳本urlvar worker = new Worker(’worker.js’);//接收worker傳遞過來的數據worker.onmessage = function(event){ document.getElementById(’result’).innerHTML+=event.data+'<br/>' ;}; };</script> </head> <body onload = 'init()'><div id='result'></div> </body></html>

下面是worker.js的內容:

var i = 0;function timedCount(){ for(var j = 0, sum = 0; j < 100; j++){for(var i = 0; i < 100000000; i++){ sum+=i;}; }; //將得到的sum發送回主線程 postMessage(sum);};//將執行timedCount前的時間,通過postMessage發送回主線程postMessage(’Before computing, ’+new Date());timedCount();//結束timedCount后,將結束時間發送回主線程postMessage(’After computing, ’ +new Date());

上面代碼執行的流程是:創建的worker對象,并用onmessage方法接收worker.js里面postMessage傳遞過來的數據(event.data),并將數據追加到div#result中。

所以,執行上面的代碼結果如下:

如何使用JS中的webWorker

圖一

待worker.js中的timedCount方法運算完后,執行postMessage操作,向主線程傳數據,得圖二。期間,并不影響主線程的運作。

如何使用JS中的webWorker

圖二

二、webWorker之常用API

接下來,再來看看關于worker的常用API:

1、postMessage(data)

子線程與主線程之間互相通信使用方法,傳遞的data為任意值。

//worker = new Worker(’url’);//worker.postMessage傳遞給子線程數據,對象worker.postMessage({first:1,second:2});//子線程中也可以使用postMessage,如傳遞字符串postMessage(‘test’);2、terminate()

主線程中終止worker,此后無法再利用其進行消息傳遞。注意:一旦terminate后,無法重新啟用,只能另外創建。

//worker = new Worker(’url’);worker.terminate();

如,主頁面:

<!DOCTYPE html> <head><title>worker</title><meta http-equiv='Content-Type' content='text/html; charset=utf-8'/><script> function init(){var worker = new Worker(’worker.js’);//每隔100毫秒,向子線程傳遞{name: ’monkey’}信息setInterval(function(){ worker.postMessage({name: ’monkey’});},100);//當主線程worker收到來自子線程的消息后,觸發message事件worker.onmessage = function(event){ document.getElementById(’result’).innerHTML+=event.data+'<br/>' ; //主線程使用terminate方法中斷與子線程來往,在瀏覽器中只能顯示一次event.data worker.terminate();}; };</script> </head> <body onload = 'init()'><div id='result'></div> </body></html>

子線程worker.js代碼:

//當主線程發來信息后,觸發該message事件onmessage = function(event){ //向主線程發送event.data.name信息 postMessage(event.data.name);};3、message

當有消息發送時,觸發該事件。且,消息發送是雙向的,消息內容可通過data來獲取。

message使用,可見terminate中的demo

4、error

出錯處理。且錯誤消息可以通過e.message來獲取。

如下:

//worker = new Worker(’url’);worker.onerror = function(e){ //打印出錯消息 console.log(e.message); //中斷與子線程的聯系 worker.terminate();}

另:worker線程從上到下同步運行它的代碼,然后進入異步階段來對事件及計時器響應,如果worker注冊了message事件處理程序,只要其有可能觸發,worker就一直在內存中,不會退出,所以通信完畢后得手動在主線程中terminate或者子線程中close掉,但如果worker沒有監聽消息,那么當所有任務執行完畢(包括計數器)后,他就會退出。

三、worker上下文

先看下面這段代碼:

主頁面:

<!DOCTYPE html> <head><title>worker</title><meta http-equiv='Content-Type' content='text/html; charset=utf-8'/><script> function init(){var worker = new Worker(’worker.js’);//接收消息事件worker.onmessage = function(event){ console.log(event.data);};//錯誤信息事件worker.onerror = function(e){ console.log(’erro: ’ + e.message); //終止線程 worker.terminate();}; };</script> </head> <body onload = 'init()'> </body></html>

worker.js

//window對象的alert方法alert(1);onmessage = function(event){ //向主線程發送event.data.name信息 postMessage(event.data.name);};

執行上面代碼結果:

如何使用JS中的webWorker

為什么會這樣呢?原因是alert為window對象的方法,所以會報錯undefined。

worker.js執行的上下文,與主頁面html執行時的上下文并不相同,最頂層的對象并不是window,woker.js執行的全局上下文,是個叫做WorkerGlobalScope的東東,所以無法訪問window、與window相關的DOM API,但是可以與setTimeout、setInterval等協作。

WorkerGlobalScope作用域下的常用屬性、方法如下:

1、self

我們可以使用 WorkerGlobalScope 的 self 屬性來或者這個對象本身的引用

2、location

location 屬性返回當線程被創建出來的時候與之關聯的 WorkerLocation 對象,它表示用于初始化這個工作線程的腳步資源的絕對 URL,即使頁面被多次重定向后,這個 URL 資源位置也不會改變。

3、close

關閉當前線程,與terminate作用類似

4、importScripts

我們可以通過importScripts()方法通過url在worker中加載庫函數

5、XMLHttpRequest

有了它,才能發出Ajax請求

6、setTimeout/setInterval以及addEventListener/postMessage

四、關于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.IE這個新特性

以上就是淺談webWorker的詳細內容,更多關于淺談webWorker的資料請關注好吧啦網其它相關文章!

標簽: JavaScript
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
国产精品伦理一区二区| 7777精品伊人久久久大香线蕉完整版| 免费不卡亚洲欧美| 欧美sm极限捆绑bd| 男人的j进女人的j一区| 国产人成精品一区二区三| 国产色91在线| 国产成人免费高清| 欧美亚洲国产一区二区三区va| 国产精品女主播av| 亚洲成人av一区二区| 国产精品mm| 精品福利在线导航| 精品在线视频一区| 色噜噜夜夜夜综合网| 一区二区三区四区激情| 欧美色综合网| 久久亚洲一级片| 国产一区二区三区国产| 在线视频国内一区二区| 午夜欧美在线一二页| 99国产精品自拍| 国产精品国产三级国产普通话99| 99热这里都是精品| 欧美一区二区观看视频| 精品一区二区免费视频| 玖玖玖国产精品| 亚洲国产日韩a在线播放性色| 一区二区亚洲精品| 国产女主播一区| 91浏览器入口在线观看| 日韩欧美的一区二区| 国产精品一级片| 欧美美女一区二区在线观看| 美女一区二区久久| 欧美性欧美巨大黑白大战| 日韩精品成人一区二区三区| 免费亚洲网站| 五月天激情综合| 国产午夜久久| 一区二区三区欧美在线观看| 国产欧美日韩综合一区在线播放 | 国产精品日韩精品欧美精品| 亚洲三级电影全部在线观看高清| 激情欧美日韩一区| 国产精品嫩草99a| 国产综合色一区二区三区| 国产精品三级久久久久三级| 国产一区免费电影| 69精品人人人人| 国产福利一区二区三区视频在线| 51精品久久久久久久蜜臀| 久久99精品视频| 欧美美女bb生活片| 丁香天五香天堂综合| 欧美大片免费久久精品三p | 午夜精品影院| 中文字幕亚洲在| 亚洲伦理一区| 亚洲成av人影院| 91福利精品视频| 狠狠色狠狠色综合日日91app| 91精品国产综合久久精品app | 91麻豆swag| 国产精品污污网站在线观看| 国产精品国产精品| 一区二区三区在线播| 亚洲影音先锋| 日韩av不卡在线观看| 欧美日韩日日骚| 丁香网亚洲国际| 欧美经典一区二区| 日韩视频在线播放 | 欧美视频精品在线观看| 国产宾馆实践打屁股91| 欧美精品一区二区三区蜜桃| 欧美日韩免费高清| 亚洲欧洲精品一区二区三区| 日本高清不卡视频| 一区二区三区四区视频精品免费| 狠狠色噜噜狠狠色综合久| 亚洲福利免费| 欧美日韩精品电影| 2019国产精品| 91视频观看视频| 免费成人在线影院| 久久综合综合久久综合| 久久av资源网| 毛片av一区二区三区| 欧美日韩成人综合在线一区二区 | 丁香天五香天堂综合| 国产91富婆露脸刺激对白| 韩国一区二区三区美女美女秀| 日本一区二区三区国色天香| 波多野结衣在线aⅴ中文字幕不卡| 亚洲二区三区四区| 精品亚洲国内自在自线福利| 国产欧美一区二区三区网站 | 中文字幕制服丝袜成人av | 久久人人97超碰人人澡爱香蕉 | 成人美女在线观看| 1区2区3区国产精品| 一区二区三区四区五区精品| 天堂一区二区在线| 欧美日本一道本| 成人av资源在线| 亚洲欧美一区二区在线观看| 久久久久久精| 国产99久久久久久免费看农村| 亚洲精品乱码久久久久久久久 | 天天免费综合色| 777奇米四色成人影色区| 91女神在线视频| 综合欧美亚洲日本| 色噜噜偷拍精品综合在线| 国产一区二区不卡老阿姨| www日韩大片| 亚洲国产mv| 成人app在线| 亚洲精品中文在线影院| 欧美中文字幕亚洲一区二区va在线| 国产成人av在线影院| 国产精品伦理一区二区| 色婷婷综合五月| 成人在线综合网站| 爽好多水快深点欧美视频| 日韩精品一区二区三区中文不卡| 亚洲国产sm捆绑调教视频| 欧美日韩美女一区二区| 91在线高清观看| 亚洲成人综合视频| 精品人伦一区二区色婷婷| 亚洲电影在线| 国产剧情一区在线| 中文字幕一区在线观看视频| 色综合久久88色综合天天| 国产二区国产一区在线观看| 香蕉成人伊视频在线观看| 精品国产乱码久久久久久免费| 99视频精品免费观看| 国产精品一区二区不卡| 亚洲蜜臀av乱码久久精品| 欧美日韩国产美| 国内揄拍国内精品久久| 亚洲国产成人porn| 中文字幕日韩一区| 欧美欧美欧美欧美首页| 影音先锋久久精品| 国产精品99久久久久久久女警| 亚洲免费在线电影| 正在播放亚洲一区| 一本色道久久综合亚洲精品不卡 | 精品福利av导航| 国产精品五区| 成人污污视频在线观看| 亚洲一二三四久久| 中文在线资源观看网站视频免费不卡| 色综合亚洲欧洲| 麻豆国产一区二区| 亚洲女人****多毛耸耸8| 欧美一级电影网站| 乱人伦精品视频在线观看| 欧美精品1区| 国产麻豆精品久久一二三| 亚洲日本在线看| 中文字幕第一页久久| 欧美日韩国产在线播放网站| 亚洲精品黄色| 成人高清免费观看| 奇米影视一区二区三区小说| 亚洲欧美日韩国产中文在线| 91精品国产一区二区人妖| 亚洲一级在线| 国产农村妇女精品一二区| 欧美xxx在线观看| 国产精品99久久久久久久vr | 欧美丝袜丝交足nylons图片| 激情欧美亚洲| 成人动漫精品一区二区| 日精品一区二区三区| 国产亚洲成aⅴ人片在线观看| 欧美日韩一二区| 99成人精品| 国产在线精品一区二区中文| 国产成人99久久亚洲综合精品| 婷婷中文字幕综合| 中文字幕日韩精品一区| 欧美xxxxx裸体时装秀| 欧美xxxxx牲另类人与| 欧美精品国产精品| 久久久夜精品| 国产日韩欧美一区二区三区在线观看| www.欧美精品一二区| 国内精品伊人久久久久影院对白| 日韩伦理电影网| 精品久久久久久久久久久久久久久| 欧美日韩综合一区| 一本一道波多野结衣一区二区| 午夜一区不卡| 正在播放亚洲|