Web Worker

Web Worker

1.特征

长时间运行,理想的运行启动性能,以及理想的内存消耗。
用于支持多线程编程,它在web程序中可并发执行多个脚本,彼此间相互独立。
分为两种线程 Dedicated Worker专用线程,Shared Worker共享线程。

2.简单示例

a.html
<html>
    <script>
        window.οnlοad=function(){
            var worker=new Worker('worker.js);
            worker.onmessage=function(event){
                console.log(event);
            }
        }
    </script>
</html>


worker.js
<script>
    let sum=1;
    function fun(){
        for(let i=0;i<10;i++){
            sum+=i;
            postMessage(sum);
        }
    }
    postMessage(new Date());
    fun();
    postMessage(new Date());
</script>


3.worker常用api

a.html:
var worker=new Worker('worker.js);
worker.postMessage({msg:'hahah'});  //向子级传递参数
worker.οnerrοr=function(e){         //出错时执行方法
    console.log(e);
    worker.terminate();             //中断该线程
}
worker.js
onmessage=function(event){          //获取主线程参数
    console.log(event);
    postMessage(event);
}

4.worker执行上下文

worker有个自己单独的上下文,名叫WorkerGlobalScope;与window不同,因此不能访问
window及window相关api,比如dom;
常用api:
self:相当于this
close():关闭当前线程相当于terminate
importScripts('*.js'):加载其他js文件

XMLHttpRequest,setTimeout/setInterval以及addEventListener/postMessage

5.shared web worker(共享线程)

a.html
<html>
    <script>
        window.οnlοad=function(){
            var worker=new SharedWorker('worker.js);
            var btn=document.querySelector('btn');
            var a=document.querySelector('a');
            worker.port.addEventListener('message',function(e){
                console.log(e);
            },false);
            btn.addEventListener('click',function(){
                worker.port.postMessage('123');
            },false);
            a.οnclick=()=>{
                worker.port.postMessage('234');
            }
        }
    </script>
</html>


worker.js
<script>
    var port;
    onconnect=function(e){
        port = e.ports[0];
        port.onmessage=function(e){
            if(e.data='btn'){
                console.log(e);
            }else{
                port.postMessage('111');
            }
        }
    }
</script>


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值