久久久久久久av_日韩在线中文_看一级毛片视频_日本精品二区_成人深夜福利视频_武道仙尊动漫在线观看

HTML 5 Web開發(fā):防止瀏覽器假死的方法

一個(gè)瀏覽器至少存在三個(gè)線程:js引擎線程(處理js)、GUI渲染線程(渲染頁(yè)面)、瀏覽器事件觸發(fā)線程(控制交互)。

JavaScript引擎是基于事件驅(qū)動(dòng)單線程執(zhí)行的,JS引擎一直等待著任務(wù)隊(duì)列中任務(wù)的到來(lái)然后加以處理,瀏覽器無(wú)論再什么時(shí)候都只有一個(gè)JS線程在運(yùn)行JS程序。

GUI 渲染線程負(fù)責(zé)渲染瀏覽器界面,當(dāng)界面需要重繪(Repaint)或由于某種操作引發(fā)回流(reflow)時(shí),該線程就會(huì)執(zhí)行。但需要注意 GUI渲染線程與JS引擎是互斥的,當(dāng)JS引擎執(zhí)行時(shí)GUI線程會(huì)被掛起,GUI更新會(huì)被保存在一個(gè)隊(duì)列中等到JS引擎空閑時(shí)立即被執(zhí)行。

事件觸發(fā)線程,當(dāng)一個(gè)事件被觸發(fā)時(shí)該線程會(huì)把事件添加到待處理隊(duì)列的隊(duì)尾,等待JS引擎的處理。這些事件可來(lái)自JavaScript引擎當(dāng)前執(zhí)行的代碼塊如setTimeOut、也可來(lái)自瀏覽器內(nèi)核的其他線程如鼠標(biāo)點(diǎn)擊、AJAX異步請(qǐng)求等,但由于JS的單線程關(guān)系所有這些事件都得排隊(duì)等待JS引擎處理。

了解了瀏覽器的內(nèi)核處理方式就不難理解瀏覽器為什么會(huì)進(jìn)入假死狀態(tài)了,當(dāng)一段JS腳本長(zhǎng)時(shí)間占用著處理機(jī)就會(huì)掛起瀏覽器的GUI更新,而后面的事件響應(yīng) 也被排在隊(duì)列中得不到處理,從而造成了瀏覽器被鎖定進(jìn)入假死狀態(tài)。另外JS腳本中進(jìn)行了DOM操作,一旦JS調(diào)用結(jié)束就會(huì)馬上進(jìn)行一次GUI渲染,然后才 開始執(zhí)行下一個(gè)任務(wù),所以JS中大量的DOM操作也會(huì)導(dǎo)致事件響應(yīng)緩慢甚至真正卡死瀏覽器,如在IE6下一次插入大量的HTML。而如果真的彈出了“腳本 運(yùn)行時(shí)間過(guò)長(zhǎng)“的提示框則說(shuō)明你的JS腳本肯定有死循環(huán)或者進(jìn)行過(guò)深的遞歸操作了。

現(xiàn)在如果遇到了這種情況,我們可以做的不僅僅是優(yōu)化 代碼,html5的webWorkers提供了js的后臺(tái)處理線程的API,它允許將復(fù)雜耗時(shí)的單純js邏輯處理放在瀏覽器后臺(tái)線程中進(jìn)行處理,讓js線 程不阻塞UI線程的渲染。這個(gè)線程不能和頁(yè)面進(jìn)行交互,如獲取元素、alert等。多個(gè)線程間也是可以通過(guò)相同的方法進(jìn)行數(shù)據(jù)傳遞。

直接看代碼:

例子:用戶輸入一個(gè)數(shù)字,進(jìn)行加法運(yùn)算(+=)

以前的做法:

  1. <!DOCTYPE HTML> 
  2. <html lang="en"> 
  3. <head> 
  4.     <meta charset="UTF-8"> 
  5.     <title>webworkers--calculate</title></head> 
  6. <body> 
  7.     <input id="num" name="num" type="text"/> 
  8.     <button onclick = "calculate()">計(jì)算</button><br /> 
  9.     <div id="result" style="color:red;"></div> 
  10.     <div id="time" style="color:red;"></div> 
  11.     <script type="text/javascript" src="calculate.js"></script> 
  12.     <script type="text/javascript">        function calculate(){  
  13.             data1 = new Date().getTime();  
  14.             var num = document.getElementById("num").value;  
  15.             var val = parseInt(num,10);  
  16.             var result =0;  
  17.             for(var i =0; i<num;i++){  
  18.                 result += i;  
  19.             }  
  20.             data2 = new Date().getTime();  
  21.             document.getElementById("result").innerHTML ="計(jì)算結(jié)果:"+result;  
  22.             document.getElementById("time").innerHTML ="普通 耗時(shí):"+ (data2 - data1)+"ms";  
  23.         }  
  24.     </script> 
  25. </body> 
  26. </html> 

使用webWorkers以后:

calculate.html

  1. <!DOCTYPE HTML> 
  2. <html lang="en"><head> 
  3.     <meta charset="UTF-8"> 
  4.     <title>webworkers--calculate</title> 
  5. </head> 
  6. <body> 
  7.     <input id="num" name="num" type="text"/> 
  8.     <button onclick = "calculate()">計(jì)算</button><br /> 
  9.     <div id="result" style="color:red;"></div> 
  10.     <div id="time" style="color:red;"></div> 
  11.     <script type="text/javascript" src="calculate.js"></script> 
  12.     <script type="text/javascript"> 
  13.         var worker = new Worker("calculate.js");  
  14.         var data1 =0;  
  15.         var data2 =0;  
  16.         worker.onmessage = function(event){  
  17.                 var data = event.data;  
  18.                 data2 = new Date().getTime();  
  19.                 document.getElementById("result").innerHTML ="計(jì)算結(jié)果:"+data;  
  20.                 document.getElementById("time").innerHTML ="workers 耗時(shí):"+ (data2 - data1)+"ms";  
  21.             };  
  22.          function calculate(){  
  23.             data1 = new Date().getTime();  
  24.             var num = document.getElementById("num").value;   
  25.            var val = parseInt(num,10);  
  26.             worker.postMessage(val);  
  27.         }  
  28.     </script> 
  29. </body> 
  30. </html> 

calculate.js

  1. onmessage = function(event){  
  2.     var num = event.data;  
  3.     var result = 0;  
  4.     for(var i = 0; i<num;i++){  
  5.         result += i;  
  6.     }  
  7.     postMessage(result);  
  8. }; 

webWorker需要將代碼放入web服務(wù)器中, 如果使用的是localhost請(qǐng)用高版本的chrome瀏覽器打開,firefox瀏覽器在處理localhost的時(shí)候會(huì)出現(xiàn)“Could not get domain!”的錯(cuò)誤,關(guān)于這個(gè)可以參考:https://bugzilla.mozilla.org/show_bug.cgi?id=682450 對(duì)比上面的兩種實(shí)現(xiàn)方式,當(dāng)計(jì)算值達(dá)到100億的時(shí)候,普通做法耗時(shí)已經(jīng)很長(zhǎng),且一般會(huì)卡死了。

HTML 5 Web開發(fā):防止瀏覽器假死的方法 三聯(lián)

webWorkers在Chrome15下的效果

更正:getTime()返回的應(yīng)該是毫秒(ms),而不是秒(s)。

如下圖所示:

普通方法在Chrome15下的效果

可見webWorkers在未來(lái)的web應(yīng)用中還是非常有價(jià)值的。

【網(wǎng)站聲明】本站除付費(fèi)源碼經(jīng)過(guò)測(cè)試外,其他素材未做測(cè)試,不保證完整性,網(wǎng)站上部分源碼僅限學(xué)習(xí)交流,請(qǐng)勿用于商業(yè)用途。如損害你的權(quán)益請(qǐng)聯(lián)系客服QQ:2655101040 給予處理,謝謝支持。

相關(guān)文檔推薦

這篇文章主要介紹了有關(guān)HTML5頁(yè)面在iPhoneX適配問(wèn)題,需要的朋友可以參考下
本篇文章主要介紹了html5中canvas圖表實(shí)現(xiàn)柱狀圖的示例,本文使用canvas來(lái)實(shí)現(xiàn)一個(gè)圖表,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
Adobe公司出品的多媒體處理軟件產(chǎn)品線較多,涵蓋了音視頻編輯、圖像處理、平面設(shè)計(jì)、影視后期等領(lǐng)域。這篇文章主要介紹了Adobe Html5 Extension開發(fā)初體驗(yàn)圖文教程,非常不錯(cuò),需要的朋
這篇文章主要介紹了基于HTML5的WebGL經(jīng)典3D虛擬機(jī)房漫游動(dòng)畫,需要的朋友可以參考下
這篇文章主要介紹了手機(jī)端用rem+scss做適配的詳解,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
本篇文章主要介紹了canvas 實(shí)現(xiàn) github404動(dòng)態(tài)效果的示例代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
主站蜘蛛池模板: 亚洲入口 | 一二三区av | 久久午夜国产精品www忘忧草 | 九九导航 | 久久综合九色综合欧美狠狠 | 久久视频免费观看 | 中文一区二区 | 狠狠干狠狠插 | 视频1区 | 超碰成人免费 | 亚洲一区二区网站 | 亚洲色图婷婷 | 午夜电影网站 | 精品无码久久久久久国产 | 草草视频在线免费观看 | 久久精品小视频 | 一级在线免费观看 | aaa大片免费观看 | 精品国产黄a∨片高清在线 成人区精品一区二区婷婷 日本一区二区视频 | 亚洲劲爆av | 精品国产视频 | 中文字幕日韩一区二区 | www.9191.com| 国产精品久久久久久一级毛片 | 国产高清精品一区二区三区 | 精品欧美黑人一区二区三区 | 精品久久久久久亚洲精品 | 黑人巨大精品 | 羞羞网站免费 | 看片一区 | 一级美国黄色片 | 伊人春色在线 | 精品99久久久久久 | 91精品国产综合久久久久 | 久久亚 | 日韩免费网站 | av色在线| 一级黄色片免费 | 91精品国产色综合久久 | 国产亚洲精品a | 午夜视频免费在线观看 |