日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

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

如何使用JS中的webWorker

瀏覽:218日期: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> //添加到任務隊列中,待同步任務所處的‘執(zhí)行棧’執(zhí)行完畢,1秒后執(zhí)行任務隊列中的這個匿名函數 setTimeout(function(){console.log(’come on’); },1000); //只要不關閉該alert,‘執(zhí)行棧’就沒結束,從而也就不會進入到任務隊列中 alert(’waiting’);</script> </body></html>

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

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

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

如下,主頁面:

<!DOCTYPE html> <head><title>worker</title><meta http-equiv='Content-Type' content='text/html; charset=utf-8'/><script> function init(){//創(chuàng)建一個Worker對象,并向它傳遞將在新線程中執(zhí)行的腳本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發(fā)送回主線程 postMessage(sum);};//將執(zhí)行timedCount前的時間,通過postMessage發(fā)送回主線程postMessage(’Before computing, ’+new Date());timedCount();//結束timedCount后,將結束時間發(fā)送回主線程postMessage(’After computing, ’ +new Date());

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

所以,執(zhí)行上面的代碼結果如下:

如何使用JS中的webWorker

圖一

待worker.js中的timedCount方法運算完后,執(zhí)行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后,無法重新啟用,只能另外創(chuàng)建。

//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收到來自子線程的消息后,觸發(fā)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代碼:

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

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

message使用,可見terminate中的demo

4、error

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

如下:

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

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

三、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){ //向主線程發(fā)送event.data.name信息 postMessage(event.data.name);};

執(zhí)行上面代碼結果:

如何使用JS中的webWorker

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

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

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

1、self

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

2、location

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

3、close

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

4、importScripts

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

5、XMLHttpRequest

有了它,才能發(fā)出Ajax請求

6、setTimeout/setInterval以及addEventListener/postMessage

四、關于worker

我們可以做什么:

1.可以加載一個JS進行大量的復雜計算而不掛起主進程,并通過postMessage,onmessage進行通信

2.可以在worker中通過importScripts(url)加載另外的腳本文件

3.可以使用setTimeout(), clearTimeout(), setInterval(), and clearInterval()

4.可以使用XMLHttpRequest來發(fā)送請求

5.可以訪問navigator的部分屬性

局限性:

1.不能跨域加載JS

2.worker內代碼不能訪問DOM

3.各個瀏覽器對Worker的實現(xiàn)不大一致,例如FF里允許worker中創(chuàng)建新的worker,而Chrome中就不行

4.IE這個新特性

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

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲尤物av| 久久一级电影| 免费成人在线影院| 国产亚洲精品v| 午夜在线精品偷拍| 美女国产精品| 亚洲精一区二区三区| 天堂成人国产精品一区| 综合国产精品| 伊人久久大香伊蕉在人线观看热v| 中文久久精品| 亚洲精品乱码日韩| 欧美视频精品全部免费观看| 97精品资源在线观看| 国产精品夜夜夜| 精品国产中文字幕第一页| 国产va在线视频| 999久久久91| 午夜欧美精品| 日韩一区二区三区精品| 国产精品亚洲二区| 神马午夜在线视频| 99国产精品私拍| 日韩高清在线不卡| 麻豆久久久久久| 日韩精品电影| 99pao成人国产永久免费视频 | 深夜福利亚洲| 国产精选久久| 国产高潮在线| 亚洲欧洲一区二区天堂久久| 亚洲精品少妇| 国产亚洲字幕| 视频在线不卡免费观看| 亚洲天堂一区二区| 国产欧美一区二区色老头| 久久亚洲图片| 中文在线不卡| 欧美欧美黄在线二区| 成人国产精品久久| 日韩高清中文字幕一区| 无码日韩精品一区二区免费| 欧美一级二区| 日韩深夜视频| 亚洲青青久久| 国产成人精品一区二区三区免费 | 国产在线不卡| 四虎精品永久免费| 国产 日韩 欧美 综合 一区| 精品日韩视频| 日韩精品一区二区三区中文在线| 精品中文字幕一区二区三区| 欧美va天堂在线| 久久国产日韩欧美精品| 日韩国产在线| 日韩在线成人| 999国产精品永久免费视频app| 最新亚洲国产| 日韩欧美午夜| 亚洲欧美网站在线观看| 精品视频在线你懂得| 久久国产福利| 欧美激情国产在线| 亚洲另类黄色| 日韩精品久久久久久久电影99爱| 日韩av午夜在线观看| 国产在线成人| 国产成人免费精品| 日本va欧美va欧美va精品| 久久九九电影| 国产精品久久久久久模特| 亚洲成人三区| 精品成av人一区二区三区| 免费日本视频一区| 深夜视频一区二区| 日本午夜精品久久久| 欧美午夜精彩| 麻豆91精品91久久久的内涵| 视频在线观看91| 秋霞影视一区二区三区| 国产精品三级| 日精品一区二区三区| 久久在线电影| 国产一区二区视频在线看| 日本一区二区三区中文字幕| 免费观看久久av| 国产v日韩v欧美v| 久久av导航| 日韩国产高清在线| 免费在线观看日韩欧美| 日韩精品欧美| 黄色欧美在线| 国产精品玖玖玖在线资源| 亚洲有吗中文字幕| 亚洲日本网址| 国产精品久久久网站| 久久精品国产一区二区| 亚洲毛片视频| 日韩中文影院| 国产精品男女| 亚洲18在线| 夜久久久久久| 九九精品调教| 精品免费av一区二区三区| 在线天堂中文资源最新版| 成人亚洲一区| 国产精品极品在线观看| 久久午夜精品| 午夜欧美精品| 欧美天堂亚洲电影院在线观看| 久久精品五月| 国产精品videossex| 首页国产欧美久久| 国产一卡不卡| 精精国产xxxx视频在线野外| 国产精品精品| 国产成人a视频高清在线观看| 国产精品jk白丝蜜臀av小说| 91成人精品观看| 69堂免费精品视频在线播放| 妖精视频成人观看www| 在线国产一区| 在线国产一区| 欧美日韩免费观看一区=区三区| 99精品网站| 欧美成人日韩| 欧美日韩视频| 国产精品社区| 中文不卡在线| 日韩精品中文字幕吗一区二区 | 亚洲免费中文| 亚洲三级av| 日韩av中文在线观看| 日韩欧美2区| 欧美精品影院| 久久99偷拍| 亚洲综合电影| 久久要要av| 首页国产欧美日韩丝袜| 亚洲欧美久久精品| 国产精品一区二区99| 久久精品国产在热久久| 日韩欧美精品| 国产亚洲欧洲| 日本成人在线网站| 鲁大师精品99久久久| 日韩欧美精品一区| 99国产一区| 亚洲乱码视频| 美女久久久精品| 欧美日韩中文字幕一区二区三区| 国产亚洲精品自拍| 欧美色综合网| 亚洲天堂免费电影| 鲁大师成人一区二区三区| 欧美日韩国产一区二区在线观看| 老司机免费视频一区二区三区| 香蕉视频亚洲一级| 亚洲欧美不卡| 国产精品丝袜在线播放| 日韩深夜视频| 视频一区视频二区中文字幕| 国产精品自在| 丰满少妇一区| 一区三区视频| 国产日产一区| 99国产精品免费视频观看| 蜜桃传媒麻豆第一区在线观看 | 欧美日韩18| 日韩av福利| 伊人久久亚洲| 岛国精品一区| 最近国产精品视频| 国产999精品在线观看| 国产亚洲福利| 久久久免费人体| 91精品99| 国产精品一区二区三区av| re久久精品视频| 国产经典一区| 久久国产精品毛片| 成人国产精品久久| 亚洲精品韩国| 91精品国产调教在线观看| 婷婷视频一区二区三区| 四虎4545www国产精品 | 欧美日韩一区二区国产| 蜜桃av在线播放| 日本麻豆一区二区三区视频| 欧美日韩视频免费观看| 日韩国产欧美在线播放| 国产99精品| 麻豆国产精品| 一区二区日韩免费看| 精品丝袜在线| 欧美国产日韩电影| 蜜臀av在线播放一区二区三区| 岛国av在线网站| 日韩高清不卡在线| 黄色不卡一区|