亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > HTML > 正文

淺談HTML5 Web Worker的使用

2024-08-26 00:20:16
字體:
來源:轉載
供稿:網友

Web Worker是HTML5提供的一個javascript多線程解決方案,我們可以將一些大計算量的代碼交由web Worker運行而不凍結用戶界面。

一:如何使用Worker

Web Worker的基本原理就是在當前javascript的主線程中,使用Worker類加載一個javascript文件來開辟一個新的線程,起到互不阻塞執行的效果,并且提供主線程和新線程之間數據交換的接口:postMessage,onmessage。

那么如何使用呢,我們看一個例子:

//worker.jsonmessage =function (evt){  var d = evt.data;//通過evt.data獲得發送來的數據  postMessage( d );//將獲取到的數據發送會主線程}

HTML頁面:test.html

<!DOCTYPE HTML><html><head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"/> <script type="text/javascript">//WEB頁主線程var worker =new Worker("worker.js"); //創建一個Worker對象并向它傳遞將在新線程中執行的腳本的URL worker.postMessage("hello world");     //向worker發送數據 worker.onmessage =function(evt){     //接收worker傳過來的數據函數   console.log(evt.data);              //輸出worker發送來的數據 } </script> </head> <body></body></html>

用Chrome瀏覽器打開test.html后,控制臺輸出  "hello world" 表示程序執行成功。

通過這個例子我們可以看出使用web worker主要分為以下幾部分

WEB主線程:

1.通過 worker = new Worker( url ) 加載一個JS文件來創建一個worker,同時返回一個worker實例。

2.通過worker.postMessage( data ) 方法來向worker發送數據。

3.綁定worker.onmessage方法來接收worker發送過來的數據。

4.可以使用 worker.terminate() 來終止一個worker的執行。

worker新線程:

1.通過postMessage( data ) 方法來向主線程發送數據。

2.綁定onmessage方法來接收主線程發送過來的數據。

二:Worker能做什么

知道了如何使用web worker ,那么它到底有什么用,可以幫我們解決那些問題呢。我們來看一個fibonacci數列的例子。

大家知道在數學上,fibonacci數列被以遞歸的方法定義:F0=0,F1=1,Fn=F(n-1)+F(n-2)(n>=2,n∈N*),而javascript的常用實現為: 

var fibonacci =function(n) {    return n <2? n : arguments.callee(n -1) + arguments.callee(n -2);};//fibonacci(36)

在chrome中用該方法進行39的fibonacci數列執行時間為19097毫秒 ,而要計算40的時候瀏覽器直接提示腳本忙了。

由于javascript是單線程執行的,在求數列的過程中瀏覽器不能執行其它javascript腳本,UI渲染線程也會被掛起,從而導致瀏覽器進入僵死狀態。使用web worker將數列的計算過程放入一個新線程里去執行將避免這種情況的出現。具體看例子:

//fibonacci.jsvar fibonacci =function(n) {    return n <2? n : arguments.callee(n -1) + arguments.callee(n -2);};onmessage =function(event) {    var n = parseInt(event.data, 10);    postMessage(fibonacci(n));};

HTML頁面:fibonacci.html

<!DOCTYPE HTML><html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"/><title>web worker fibonacci</title><script type="text/javascript">  onload =function(){      var worker =new Worker('fibonacci.js');        worker.addEventListener('message', function(event) {        var timer2 = (new Date()).valueOf();           console.log( '結果:'+event.data, '時間:'+ timer2, '用時:'+ ( timer2  - timer ) );      }, false);      var timer = (new Date()).valueOf();      console.log('開始計算:40','時間:'+ timer );      setTimeout(function(){          console.log('定時器函數在計算數列時執行了', '時間:'+ (new Date()).valueOf() );      },1000);      worker.postMessage(40);      console.log('我在計算數列的時候執行了', '時間:'+ (new Date()).valueOf() );  }    </script></head><body></body></html>

在Chrome中打開fibonacci.html,控制臺得到如下輸出:

開始計算:40 時間:1316508212705
我在計算數列的時候執行了 時間:1316508212734
定時器函數在計算數列時執行了 時間:1316508213735
結果:102334155 時間:1316508262820 用時:50115

這個例子說明在worker中執行的fibonacci數列的計算并不會影響到主線程的代碼執行,完全在自己獨立的線程中計算,只是在計算完成之后將結果發回主線程。

利用web worker我們可以在前端執行一些復雜的大量運算而不會影響頁面的展示,并且不會彈出惡心的腳本正忙提示。

下面這個例子使用了web worker來計算場景中的像素,場景打開時是一片一片進行繪制的,一個worker只計算一塊像素值。

三:Worker的其他嘗試

我們已經知道Worker通過接收一個URL來創建一個worker,那么我們是否可以利用web worker來做一些類似jsonp的請求呢,大家知道jsonp是通過插入script標簽來加載json數據的,而script元素在加載和執行過程中都是阻塞式的,如果能利用web worker實現異步加載將會非常不錯。

下面這個例子將通過 web worker、jsonp、ajax三種不同的方式來加載一個169.42KB大小的JSON數據

// /aj/webWorker/core.jsfunction $E(id) {    return document.getElementById(id);}onload =function() {    //通過web worker加載    $E('workerLoad').onclick =function() {        var url ='http://js.wcdn.cn/aj/mblog/face2';        var d = (new Date()).valueOf();        var worker =new Worker(url);        worker.onmessage =function(obj) {            console.log('web worker: '+ ((new Date()).valueOf() - d));        };    };    //通過jsonp加載    $E('jsonpLoad').onclick =function() {        var url ='http://js.wcdn.cn/aj/mblog/face1';        var d = (new Date()).valueOf();        STK.core.io.scriptLoader({            method:'post',            url : url,            onComplete : function() {                console.log('jsonp: '+ ((new Date()).valueOf() - d));            }        });    };    //通過ajax加載    $E('ajaxLoad').onclick =function() {        var url ='http://js.wcdn.cn/aj/mblog/face';        var d = (new Date()).valueOf();        STK.core.io.ajax({            url : url,            onComplete : function(json) {                console.log('ajax: '+ ((new Date()).valueOf() - d));            }        });    };};

HTML頁面:/aj/webWorker/worker.html

<!DOCTYPE HTML><html><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8"/><title>Worker example: load data</title><script src="http://js.t.sinajs.cn/STK/js/gaea.1.14.js" type="text/javascript"></script><script type="text/javascript" src="http://js.wcdn.cn/aj/webWorker/core.js"></script></head><body>    <input type="button" id="workerLoad" value="web worker加載"></input>    <input type="button" id="jsonpLoad" value="jsonp加載"></input>    <input type="button" id="ajaxLoad" value="ajax加載"></input></body></html>

設置HOST

127.0.0.1 js.wcdn.cn

通過 http://js.wcdn.cn/aj/webWorker/worker.html 訪問頁面然后分別通過三種方式加載數據,得到控制臺輸出:

web worker: 174jsonp: 25ajax: 38

多試幾次發現通過jsonp和ajax加載數據的時間相差不大,而web worker的加載時間一直處于高位,所以用web worker來加載數據還是比較慢的,即便是大數據量情況下也沒任何優勢,可能是Worker初始化新起線程比較耗時間。除了在加載過程中是無阻塞的之外沒有任何優勢。

那么web worker是否能支持跨域js加載呢,這次我們通過http://127.0.0.1/aj/webWorker/worker.html 來訪問頁面,當點擊 "web worker加載" 加載按鈕時Chrome下無任何反映,FF6下提示錯誤。由此我們可以知道web worker是不支持跨域加載JS的,這對于將靜態文件部署到單獨的靜態服務器的網站來說是個壞消息。

所以web worker只能用來加載同域下的json數據,而這方面ajax已經可以做到了,而且效率更高更通用。還是讓Worker做它自己擅長的事吧。

四:總結

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.不是每個瀏覽器都支持這個新特性

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到HTML教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美亚洲激情在线| 久久久精品久久| 日韩在线视频线视频免费网站| 久久精品国产电影| 欧美午夜www高清视频| 亚洲xxx大片| 日韩国产激情在线| 5566日本婷婷色中文字幕97| 中文字幕日本精品| 国产精品吊钟奶在线| 91精品久久久久久久久久久久久| 欧美极度另类性三渗透| 欧美黑人一区二区三区| 九九热最新视频//这里只有精品| 国产成人自拍视频在线观看| 日韩欧美精品中文字幕| 国产精品手机播放| 青青a在线精品免费观看| 欧美一级淫片aaaaaaa视频| 色香阁99久久精品久久久| 欧美另类极品videosbestfree| 欧美大片免费看| 国产在线精品播放| 啪一啪鲁一鲁2019在线视频| 精品日本高清在线播放| 亚洲国产精品yw在线观看| 成人中文字幕+乱码+中文字幕| 久久久欧美精品| 亚洲毛片在线观看| 91精品国产网站| 日韩欧美国产网站| 国产精品偷伦视频免费观看国产| 精品久久久久久久久久国产| 国产精品av免费在线观看| 午夜精品久久久久久久久久久久| 欧美在线视频观看免费网站| 中文字幕亚洲欧美日韩2019| 日韩精品免费一线在线观看| 日韩成人av网| 午夜精品久久久99热福利| 国产一区二区日韩精品欧美精品| 亚洲人成网站色ww在线| 欧美性猛交xxxx免费看漫画| 国产+成+人+亚洲欧洲| 久久久久久网址| 国产精品天天狠天天看| 日韩男女性生活视频| 亚洲精品国偷自产在线99热| 久久精品亚洲热| 亚洲第一中文字幕| 成人有码视频在线播放| 欧美日韩亚洲视频一区| 国产精品久久久久久久久久久久久久| 伊人成人开心激情综合网| 欧美色xxxx| 亚洲欧洲成视频免费观看| 久久久久久久久国产精品| 日韩黄色av网站| 亚洲影院污污.| 亚洲区中文字幕| 久久99国产精品久久久久久久久| 欧美成人精品激情在线观看| 奇门遁甲1982国语版免费观看高清| 91精品在线观| 亚州精品天堂中文字幕| 欧美激情18p| 久久人人看视频| 日韩av色在线| 日本精品久久久久影院| 亚洲国产精品va在看黑人| 亚洲精品电影久久久| 成人免费网站在线| 成人网在线视频| 欧美亚洲在线视频| 日韩视频精品在线| 国产成人精品视频在线| 亚洲欧美国产一本综合首页| 久久久久久这里只有精品| 亚洲国产另类 国产精品国产免费| 久久99精品久久久久久噜噜| 国产精品国产三级国产aⅴ浪潮| 欧美性猛交xxx| 久久青草福利网站| 美女视频黄免费的亚洲男人天堂| 久久频这里精品99香蕉| 国产成人精品国内自产拍免费看| 亚洲精品国产精品久久清纯直播| 黑丝美女久久久| 98精品在线视频| 97国产suv精品一区二区62| 欧美成人高清视频| 狠狠色狠狠色综合日日五| 中文字幕日韩av综合精品| 日韩中文字幕在线视频| 亚洲欧美日韩一区二区三区在线| 国产精品爽黄69| 欧美精品videos另类日本| 日韩亚洲成人av在线| 中文字幕九色91在线| 国产精品欧美日韩久久| 国产中文日韩欧美| 欧美日韩美女视频| 亚洲成人中文字幕| 最近2019中文字幕大全第二页| 久久精品精品电影网| 欧美黄色性视频| 日韩精品在线看| 亚洲精品久久久久久久久久久久久| 国产大片精品免费永久看nba| 成人免费福利视频| 国产亚洲精品91在线| 国产精品久久二区| 久久久久久久久网站| 国产精品一久久香蕉国产线看观看| 国产午夜精品一区二区三区| www.日韩不卡电影av| 亚洲成人xxx| 日韩欧美一区二区三区久久| 日韩精品在线免费| 97av在线视频| 欧美影院在线播放| 国产精品视频免费观看www| 亚洲最大激情中文字幕| 日韩国产高清污视频在线观看| 亚洲xxxx妇黄裸体| 1769国产精品| 国产精品日韩专区| 日本不卡高字幕在线2019| 国产视频久久久久| 亚洲国产成人在线播放| 日韩精品一区二区三区第95| 久久69精品久久久久久久电影好| 成人免费看吃奶视频网站| 日本在线精品视频| 精品免费在线观看| 日本久久久久亚洲中字幕| 国产精品一区av| 国产视频精品自拍| 1769国内精品视频在线播放| 亚洲激情免费观看| 国产精品视频免费在线观看| 91av在线精品| 国产精品视频久| 国外成人在线视频| 91精品国产自产在线| 一区二区欧美久久| 欧美日韩国产麻豆| 中文字幕av一区中文字幕天堂| 欧美专区在线播放| 国产精品人人做人人爽| 国产精品热视频| 91最新在线免费观看| 久久99久久99精品中文字幕| 日韩免费在线免费观看| 青青精品视频播放| 午夜精品福利电影| 91精品国产91久久久久久不卡| 在线视频免费一区二区| 成人精品网站在线观看| xvideos亚洲人网站| 亚洲精品免费一区二区三区| 欧美高清自拍一区| 91高清视频免费| 性金发美女69hd大尺寸|