您当前的位置:首页 > 电脑百科 > 程序开发 > 编程百科

Worker基础知识

时间:2019-08-29 17:45:03  来源:  作者:

我们都知道客户端JAVAScript有一个基本的特性就是单线程。这是有一定历史原因的,暂且不深究。随着web应用的越来越复杂,客户端的js可能会承担越来越繁重的计算任务,从而导致UI线程被阻塞无法及时响应用户的操作。

worker的出现,就是来解放主线程的js的计算任务的,由于安全的考虑,worker也会受到一定的限制。

1. 基本知识

在Web Worker标准中,定义了解决客户端JavaScript无法多线程的问题。

  1. worker是指执行代码的并行线程。
  2. Web Workers处在一个自包含的执行环境,无法访问Window对象和Document对象,
  3. 和主线程之间的通信也只能通过异步消息传递机制来实现。
  4. 提供一种使用异步API的方式,同时运行书写需要长时间运行的函数而不会带来循环事件和导致浏览器崩溃的问题。
  5. Web Workers标准中,有两部分组成Worker对象和WorkerGlobalScope全局对象。

2. Worker对象

  1. 使用构造函数Worker()创建Worker对象
var loader = new Worker(url)
  1. url:可以采用相对路径和绝对路径,但是采用绝对路径必须和包含该脚本的文档是同源的。
  2. 使用postMessage()传递参数给Worker
  3. 传递给postMessage()方法的值hi赋值,最终的副本会通过message事件传递给Worker
loader.postMessage('file.txt');
  1. 通过message事件来接收Work的响应消息
worker.onmessage = function(e){
 var message = e.data;
 console.log('URL contents: ' + message);
}
  1. 使用terminate()终止Worker
worker.onmessage = function(e){
 //接收处理Worker的响应消息
 //终止worker
 worker.terminate();
}

此外,Worker可以通过error事件来处理异常。

worker.onerror = function(e){
 concole.log('Error at ' + e.filename + ':' + e.lineno
 + ':' + e.message);
}

和所有事件目标一样,Worker对象也定义了标准的addEventListener()和removeEventListener()

3. WorkerGlobalScope全局对象

在通过Worker()构造函数创建一个新Worker的时候,指定了包含JavaScript代码文件的URL。该代码会运行在一个全新的JavaScript运行环境中,完全和创建Worker的脚本隔离开来。

WorkerGlobalScope全局对象表示了该新的运行环境,它是新创建的Worker的全局对象。

3.1 与外部Worker的通信

1. postMessage() & message事件

WorkerGlobalScope对象同样有postMessage()方法和message事件,利用这两者可以与外部Worker进行通信

//worker内部
onmessage = function(e){
 postMessage(e.data);
}

2. close()

同样,Worker可以使用close()来关闭自己,但是要注意的是,Worker对象上没有定义任何API用于检测Worker是否已关闭。因此,如果一个Worker要使用close()方法将自己关闭,那么最好是先传递”关闭”的信息。

3. importScripts()

Worker内部使用此方法来加载任何需要的库代码。而是此方法是一个同步的方法,它在直到所有的脚本都已经载入并运行完成才会返回。

//在开始工作前,现在如需要的类、工具函数
importScript('collections/Set.js','utils/base64.js');

3.2 WorkerGlobalScope的属性

它拥有所有核心JavaScript全局对象拥有的属性,同时,还拥有部分客户端Window对象的一些属性。

  • self:对全局对象自身的引用
  • 计数器方法:setTimeout()/clearTimeout()/setInterval()/clearInterval()
  • location:只读
  • navigator
  • 常用的事件目标方法:addEventListener()和removeEventListener()
  • onerror属性

4. 应用场景:脚本化HTTP请求

WorkerGlobalScope对象好包含一些重要的构造函数,其中就有XMLHttpRequest(),以便Worker可以通过它进行脚本化的HTTP请求。

在Worker中发起同步的XmlHttpRequest

//Worker内部
onmessage = function(e){
 var urls = e.data; //要获取的url
 var contents = []; //url指定的内容
 var i,len,url;
 for(i = 0, len = urls.length; i < len; i++){
 var url = urls[i];
 var xhr = new XMLHttpRequest();
 xhr.open('GET',url,false);//false表示进行同步请求
 xhr.send();
 if(xhr.status !== 200){
 throw Error(xhr.status + ' ' + xhr.statusText + ': ' + url);
 }
 contents.push(xhr.responseText);
 }
 //返回url的内容
 postMessage(contents);
}


Tags:Web Worker   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
我们都知道客户端JavaScript有一个基本的特性就是单线程。这是有一定历史原因的,暂且不深究。随着web应用的越来越复杂,客户端的js可能会承担越来越繁重的计算任务,从而导致UI...【详细内容】
2019-08-29  Tags: Web Worker  点击:(523)  评论:(0)  加入收藏
▌简易百科推荐
本文分为三个等级自顶向下地分析了glibc中内存分配与回收的过程。本文不过度关注细节,因此只是分别从arena层次、bin层次、chunk层次进行图解,而不涉及有关指针的具体操作。前...【详细内容】
2021-12-28  linux技术栈    Tags:glibc   点击:(3)  评论:(0)  加入收藏
摘 要 (OF作品展示)OF之前介绍了用python实现数据可视化、数据分析及一些小项目,但基本都是后端的知识。想要做一个好看的可视化大屏,我们还要学一些前端的知识(vue),网上有很多比...【详细内容】
2021-12-27  项目与数据管理    Tags:Vue   点击:(2)  评论:(0)  加入收藏
程序是如何被执行的&emsp;&emsp;程序是如何被执行的?许多开发者可能也没法回答这个问题,大多数人更注重的是如何编写程序,却不会太注意编写好的程序是如何被运行,这并不是一个好...【详细内容】
2021-12-23  IT学习日记    Tags:程序   点击:(9)  评论:(0)  加入收藏
阅读收获✔️1. 了解单点登录实现原理✔️2. 掌握快速使用xxl-sso接入单点登录功能一、早期的多系统登录解决方案 单系统登录解决方案的核心是cookie,cookie携带会话id在浏览器...【详细内容】
2021-12-23  程序yuan    Tags:单点登录(   点击:(8)  评论:(0)  加入收藏
下载Eclipse RCP IDE如果你电脑上还没有安装Eclipse,那么请到这里下载对应版本的软件进行安装。具体的安装步骤就不在这赘述了。创建第一个标准Eclipse RCP应用(总共分为六步)1...【详细内容】
2021-12-22  阿福ChrisYuan    Tags:RCP应用   点击:(7)  评论:(0)  加入收藏
今天想简单聊一聊 Token 的 Value Capture,就是币的价值问题。首先说明啊,这个话题包含的内容非常之光,Token 的经济学设计也可以包含诸多问题,所以几乎不可能把这个问题说的清...【详细内容】
2021-12-21  唐少华TSH    Tags:Token   点击:(10)  评论:(0)  加入收藏
实现效果:假如有10条数据,分组展示,默认在当前页面展示4个,点击换一批,从第5个开始继续展示,到最后一组,再重新返回到第一组 data() { return { qList: [], //处理后...【详细内容】
2021-12-17  Mason程    Tags:VUE   点击:(14)  评论:(0)  加入收藏
什么是性能调优?(what) 为什么需要性能调优?(why) 什么时候需要性能调优?(when) 什么地方需要性能调优?(where) 什么时候来进行性能调优?(who) 怎么样进行性能调优?(How) 硬件配...【详细内容】
2021-12-16  软件测试小p    Tags:性能调优   点击:(20)  评论:(0)  加入收藏
Tasker 是一款适用于 Android 设备的高级自动化应用,它可以通过脚本让重复性的操作自动运行,提高效率。 不知道从哪里听说的抖音 app 会导致 OLED 屏幕烧屏。于是就现学现卖,自...【详细内容】
2021-12-15  ITBang    Tags:抖音防烧屏   点击:(25)  评论:(0)  加入收藏
11 月 23 日,Rust Moderation Team(审核团队)在 GitHub 上发布了辞职公告,即刻生效。根据公告,审核团队集体辞职是为了抗议 Rust 核心团队(Core team)在执行社区行为准则和标准上...【详细内容】
2021-12-15  InfoQ    Tags:Rust   点击:(25)  评论:(0)  加入收藏
相关文章
    无相关信息
最新更新
栏目热门
栏目头条