js 创建多线程的方法 Worker

JavaScript023

js 创建多线程的方法 Worker,第1张

Worker 支持主流的浏览器 IE10 以下不支持

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对象并向它传递将在新线程中执行的脚本的URL

 worker.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://),它所加载的脚本,必须来自网络。