html5的webWorker學習

當主要的耗時操作都在操作dom的時候,webWorker是無能爲力的
Worker是瀏覽器爲js新開的一個線程,可以不影響當前頁面的情況下,在另外的線程中執行計算並把結果回傳給主線程.

一.專用Worker

交互通信過程通過onmessage和postMessage方法
主線程main.js , 子線程myWorker.js

主線程發送消息到子線程和主線程接收子線程的消息

var myWorker = new Worker('myWorker.js');
// 主線程發送消息到子線程
myWorker.postMessage(obj);
// 主線程接收子線程的消息
myWorker.onmessage = function (e) {
    console.log(e);
};

子線程發送消息和接收消息

// 子線程接收消息
onmessage = function (e) {
    console.log(e);
};
// 子線程發送消息
postMessage([{syc:'text1'},{syc:'text2'},{syc:'text3'}]);

主線程監聽子線程的錯誤信息

myWorker.addEventListener('error',function (e) {
        console.error(e.filename);
        console.error(e.message);
        console.error(e.lineno);
    });

完整的例子
main.js

// 檢測瀏覽器是否支持Worker
if (window.Worker) {
    var myWorker = new Worker('myWorker.js');
    myWorker.onmessage = function (e) {
        console.log(e);
    };
    var obj = {
        number:100,
        arr:[{text:1},{text:1}],
        b:true,
        str:'string'
    };
    myWorker.addEventListener('error',function (e) {
        console.error(e.filename);
        console.error(e.message);
        console.error(e.lineno);
    });
    myWorker.postMessage(obj);
} else {
    alert("瀏覽器不支持Worker");
}

myWorker.js

onmessage = function (e) {
    console.log(e);
};

console.log(self);
postMessage([{syc:'text1'},{syc:'text2'},{syc:'text3'}]);
throw new Error('myWorker 主動拋出錯誤');
postMessage([1,2,3]);
postMessage(123);

二.共享Worker

共享Worker和專用Worker有相同的API,但是,共享Worker要在一個確切打開的端口中通信,也就是端口必須被顯示的打開,而打開的方式就是使用onmessage事件,或者顯示的調用start方法.若是使用start方法顯示打開的端口,此時若要主線程和共享子線程雙向通信就要在子線程中也調用start.
main.js

if(window.SharedWorker){
    var sw = new SharedWorker('./sharedWorker.js');
    // sw.port.start();
    sw.port.postMessage(2);
    sw.port.onmessage = function (e) {
        console.log(e);
    }
} else {
    alert("瀏覽器不支持Worker");
}

main2.js

if(window.SharedWorker){
    var sw = new SharedWorker('./sharedWorker.js');
    // sw.port.start();
    sw.port.postMessage(1);
    sw.port.onmessage = function (e) {
        console.log(e);
    }
} else {
    alert("瀏覽器不支持Worker");
}

sharedWorker.js

onconnect = function (e) {
    var port = e.ports[0];

    port.onmessage = function (e) {
        console.log(e.data);
        port.postMessage('sharedWorker發送了消息'+e.data);
    };

    // port.start();
}
發佈了106 篇原創文章 · 獲贊 52 · 訪問量 19萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章