简介
JavaScript 语言采用的是单线程模型,所有任务只能在一个线程上完成,一次只能做一件事。前面的任务没做完,后面的任务只能等着。随着电脑计算能力的增强,尤其是多核 CPU 的出现,单线程带来很大的不便,无法充分发挥计算机的计算能力。Web Worker 的作用,就是为 JavaScript 创造多线程环境,允许主线程创建 Worker 线程,将一些任务分配给后者运行。在主线程运行的同时,Worker 线程在后台运行,两者互不干扰。等到 Worker 线程完成计算任务,再把结果返回给主线程。这样的好处是,一些计算密集型或高延迟的任务,被 Worker 线程负担了,主线程(通常负责 UI 交互)就会很流畅,不会被阻塞或拖慢。**Worker 线程一旦新建成功,就会始终运行,不会被主线程上的活动(比如用户点击按钮、提交表单)打断。**这样有利于随时响应主线程的通信。但是,这也造成了 Worker 比较耗费资源,不应该过度使用,而且一旦使用完毕,就应该关闭。
使用
- Worker 创建一个worker对象
- worker.onmessage=func 监听子线程发回的消息
- worker.postMessage(your message) 向子线程发送消息
- worker.οnerrοr=func 可以监听错误信息
- 子线程中需要绑定一个监听函数,监听message事件
addEventListener('message', function (e) {
postMessage(e.data);
}, false);
- worker.terminate() 关闭worker
使用场景
- 计算量庞大
- worker中可以通过importScript(url)来加载其他文件
- 可以使用XMLHttpRequest来发送请求
局限性
- 同源限制,分配给worker线程的文件,必须与主线程同源
- DOM限制,子线程中无法访问主线程所在网页的dom对象,无法使用document、window、parent等对象
- 通信限制,主线程和子线程必须通过postMessage进行通信
- 脚本限制,worker线程中不允许使用alert()和confirm()
- 文件限制,worker线程无法读取本地文件,只能是来自网络的文件