初探web worker

前言:js是单线程这个特性不多赘序,单线程意味着一次只能做一件事,对于现代计算机来说,存在着多个CPU,如果只使用单线程,对CPU的利用率将大大降低。而web worker的出现正式为了解决这个问题,web worker允许在后台创建线程,可以将一些比较耗时的任务交给worker线程来做,在主线程运行的同时,Worker 线程在后台运行,两者互不干扰。

一、使用注意项:

  1. web worker受到同源限制,也就是只有在同源下才能使用,即协议相同,域名相同,端口号相同。
  2. worker所在线程与主线程不一样,不能使用window,document,parent对象,不能操作dom元素,但是可以使用navigator和location对象
  3. 主线程与worker线程内存空间相互独立,不能直接通信,必须使用postMessage方法发送数据,使用onmessage事件接受数据,发送的数据可以使用任意格式,包括二进制数据。(shared worker是内存共享的,可以直接使用)
  4. Worker 线程不能执行alert()方法和confirm方法,但可以使用 XMLHttpRequest 对象发出 AJAX 请求。
  5. worker无法读取本地文件,所加载的脚本必须来源于网络。

二、使用:

  • 主线程使用:
//调用Worker构造函数来创建一个worker线程,可以接受两个参数,第一个为worker线程的位置
//第二个为一个选项参数
var wk = new Worker('worker.js')
//监听消息
wk.onmessage = function(e) {
    let data = e.data
}
//发送消息
wk.postMessage("hello world")
//发送消息
wk.postMessage({name:"六只脚"})
//关闭
wk.terminate()
  • worker线程
//self与this都指代当先worker线程

self.addEventListener("message",function(e) {
    let data = e.data
    //TODO
})

//或者
this.addEventListener("message",function(e){})
//或者
addEventListener("message",function(e){})


//发送消息
self.postMessage({age:23})

//关闭自身,在worker内部关闭自己
self.close()
  • worker加载脚本
//worker内加载脚本,使用importScripts()方法

//加载一个脚本
importScripts('a.js')
//加载多个脚本
importScripts('a.js','b.js');

三、页面嵌入web worker

<!-- 可以通过script向当前页面注入一个web worker,type的类型必须是浏览器不认识的类型 --> 
<body>
    <script id="worker" type="app/worker">
      addEventListener('message', function () {
        postMessage('some message');
      }, false);
    </script>
  </body>

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值