a.js 内容
var i =0
setInterval((function () {
postMessage(i++)
}),1000)
使用 postMessage 向主线程 传送消息
var worker =new Worker('a.js') // 写入需要引入的 js
console.log(worker)
worker.onmessage =function () {
console.log(event.data)
}
//用于关闭worker线程
worker.terminate()
可以的
var worker =new Worker("worker.js") //创建一个Worker对象并向它传递将在新线程中执行的脚本的URLworker.postMessage("hello world") //向worker发送数据
worker.onmessage =function(evt){ //接收worker传过来的数据函数
console.log(evt.data) //输出worker发送来的数据
}
同样worker.js脚本中也可以通过postMessage向主线程发送消息,通过onmessage接收主线程发来的消息
按照如下步骤分配:1.同源限制
分配给 Worker 线程运行的脚本文件,必须与主线程的脚本文件同源。
2.DOM 限制
Worker 线程所在的全局对象,与主线程不一样,无法读取主线程所在网页的 DOM 对象,也无法使用document、window、parent这些对象。但是,Worker 线程可以navigator对象和location对象。
3.通信联系
Worker 线程和主线程不在同一个上下文环境,它们不能直接通信,必须通过消息完成。
4.脚本限制
Worker 线程不能执行alert()方法和confirm()方法,但可以使用 XMLHttpRequest 对象发出 AJAX 请求。
5.文件限制
Worker 线程无法读取本地文件,即不能打开本机的文件系统(file://),它所加载的脚本,必须来自网络。