close

html5.jpg 

web worker 是運行在後台的JavaScript,不會影響頁面的性能。


什麼是Web Worker?

當在HTML 頁面中執行腳本時,頁面的狀態是不可響應的,直到腳本已完成。

web worker 是運行在後台的JavaScript,獨立於其他腳本,不會影響頁面的性能。您可以繼續做任何願意做的事情:點擊、選取內容等等,而此時web worker 在後台運行。


瀏覽器支持

所有主流瀏覽器均支持web worker,除了Internet Explorer。


檢測Web Worker 支持

在創建web worker 之前,請檢測用戶的瀏覽器是否支持它:

if(typeof(Worker)!=="undefined")
  {
  // Yes! Web worker support!
  // Some code.....
  }
else
  {
  // Sorry! No Web Worker support..
  }
	

創建web worker 文件

現在,讓我們在一個外部JavaScript 中創建我們的web worker。

在這裡,我們創建了計數腳本。該腳本存儲於"demo_workers.js" 文件中:

var i=0;
function timedCount()
{
i=i+1;
<code>postMessage(i);</code>
setTimeout("timedCount()",500);
}
timedCount();
	

以上代碼中重要的部分是postMessage()方法-它用於向HTML頁面傳回一段消息。

註釋: web worker通常不用於如此簡單的腳本,而是用於更耗費CPU資源的任務。


創建Web Worker 對象

我們已經有了web worker 文件,現在我們需要從HTML 頁面調用它。

下面的代碼檢測是否存在worker,如果不存在,- 它會創建一個新的web worker 對象,然後運行"demo_workers.js" 中的代碼:

if(typeof(w)=="undefined")
  {
  w=new Worker("demo_workers.js");
  }
	

然後我們就可以從web worker 發生和接收消息了。

向web worker 添加一個"onmessage" 事件監聽器:

w.onmessage=function(event){
document.getElementById("result").innerHTML=event.data;
};
	

當web worker 傳遞消息時,會執行事件監聽器中的代碼。event.data 中存有來自event.data 的數據。


終止Web Worker

當我們創建web worker 對像後,它會繼續監聽消息(即使在外部腳本完成之後)直到其被終止為止。

如需終止web worker,並釋放瀏覽器/計算機資源,請使用terminate() 方法:

w.terminate();
	

完整的Web Worker 實例代碼

我們已經看到了.js 文件中的Worker 代碼。下面是HTML 頁面的代碼:

實例

<!DOCTYPE html>
<html>
<body>
<p>Count numbers: <output id="result"></output></p>
<button onclick="startWorker()">Start Worker</button>
<button onclick="stopWorker()">Stop Worker</button>
<br /><br />
<script>
var w;
function startWorker()
{
if(typeof(Worker)!=="undefined")
{
  if(typeof(w)=="undefined")
    {
    w=new Worker("demo_workers.js");
    }
  w.onmessage = function (event) {
    document.getElementById("result").innerHTML=event.data;
  };
}
else
{
document.getElementById("result").innerHTML="Sorry, your browser
 does not support Web Workers...";
}
}
function stopWorker()
{
w.terminate();
}
</script>
</body>
</html>
	

Web Workers 和DOM

由於web worker 位於外部文件中,它們無法訪問下例JavaScript 對象:

  • window 對象
  • document 對象
  • parent 對象
arrow
arrow
    創作者介紹
    創作者 設計密碼工作室 的頭像
    設計密碼工作室

    Design Code 設計密碼

    設計密碼工作室 發表在 痞客邦 留言(0) 人氣()