JavaScript 语言采用的是单线程模型,也就是说,全部任务只能在一个线程上完成,一次只能作一件事。前面的任务没作完,后面的任务只能等着。随着电脑计算能力的加强,尤为是多核 CPU 的出现,单线程带来很大的不便,没法充分发挥计算机的计算能力。
Web Worker 的做用,就是为 JavaScript 创造多线程环境,容许主线程建立 Worker 线程,将一些任务分配给后者运行。在主线程运行的同时,Worker 线程在后台运行,二者互不干扰。等到 Worker 线程完成计算任务,再把结果返回给主线程。这样的好处是,一些计算密集型或高延迟的任务,被 Worker 线程负担了,主线程(一般负责 UI 交互)就会很流畅,不会被阻塞或拖慢。html
基本用法
主线程
// new Worker(url) url是跟主线程同源的worker线程文件,不能跨域 var worker = new Worker('test.worker.js'); worker.onmessage = function (event) { let data = event.data; alert(JSON.stringify(data)); } // 向Worker线程传递数据 worker.postMessage({ cmd: 'time' });
Worker线程
self.onmessage = function (event) { let param = event.data; switch (param.cmd) { case 'time': self.postMessage({ cmd: 'time', data: new Date() }) break; } }
Demo:
简单Demogit
参考:
Web Worker 使用教程
js Worker 线程web