初探web worker

初探web worker前言 js 是单线程这个特性不多赘序 单线程意味着一次只能做一件事 对于现代计算机来说 存在着多个 CPU 如果只使用单线程 对 CPU 的利用率将大大降低

大家好,欢迎来到IT知识分享网。

前言: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>

 

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/146858.html

(0)
上一篇 2025-04-11 20:00
下一篇 2025-04-11 20:10

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信