前端worker之web worker
web worker
背景
众所周知javascript是单线程的,同一时间内只能做一件事情。
这是十分必要的,设想,如果js是多线程的。有个dom元素两个线程同时做了改变,一个display:none,另一个display:block,这样让浏览器就无所适从了。出于此种考虑,单线程的js就这样一直延续下来,但是凡事必有两面性,虽然单线程保证了一些ui操作的可行性,但一些比较耗时任务, 单线程的js执行起来就会有一些不太好的体验。好一点是一直loading的提示条,更甚的可能连提示都没有,即所谓的假死状态。web worker就应运而生了。
什么是web worker
Web Workers 使得一个Web应用程序可以在与主执行线程分离的后台线程中运行一个脚本操作。把那些耗时的操作放在该线程中执行,这样就避免了主线程即UI线程被阻塞。
简而言之,就是在主线程即负责ui交互的js之外,新开一个后台脚本负责费时操作的执行。本来可能阻塞UI的操作,就直接不与dom打交道避免长时间阻塞,执行完成之后通知主线程即可。
web worker上下文
正如前面提到的,web worker诞生的目的在于解决耗时操作对ui交互的影响,所以worker不能访问和操作dom的,如果有这个能力那么上面提到同时操作的问题就又会出现了。
worker中的上下文和主线程js的上下文对象是不同的,window不是它的顶层对象,所以window相关的一些方法如alert等时不能使用的,还有dom也是不能访问的。不过基本的方法。例如console.log、setTimeout等可以访问。
worker常见可用API和属性
- setInterval/clearInterval
- setTimeout/setInterval
- Cache
- Console API
- CustomEvent
- Fetch
- FileReader/FileReaderSync
- FormData
- Promise
- WebSocket
- XMLHttpRequest
等,更多请查看Functions and classes available to Web Workers
如何创建 web worker
创建一个web worker 十分简单,只需要new worker(path),path为worker文件的路径。如下面代码所示:
// 检测是否支持window.Worker
if (window.Worker) {
// 指定worker文件路径,据此创建Worker
var worker = new Worker('./ww.js')
// 监控message,当收到worker信息时执行
worker.onmessage = function (e) {
var div = document.querySelector('#root')
div.innerHTML = e.data
}
}
通信机制
主线程js与worker 线程之间通信机制比较简单。两者通过postMessage和onmessage来传递信息。
- postMessage:发送信息,主线程js和worker都可以通过该方法发送消息,不过主线程中该方法是worker的方法,worker中可以直接调用。
- onmessage: 接受信息的事件,后面跟相应回调。
具体代码如下:
/* 主线程js发送接受消息 */
// 指定worker文件路径,据此创建Worker
var worker = new Worker('./ww.js')
var isFirst = true
// 监听message事件,当收到worker信息时执行
worker.onmessage = function(e){
var div = document.querySelector('#root')
div.innerHTML = e.data
// 首次执行,发送信息给worker
isFirst && worker.postMessage('来自主线程的消息')
isFirst =false
}
worker :
/* worker 接受发送消息 */
// 2s之后执行循环,并发送
postMessage('执行结果' + j + '执行结束时间' + new Date().toLocaleTimeString())
onmessage = function (e) {
console.log(e)
postMessage(e.data)
}
更多worker
除了上面提到的worker之外还要一下几种worker。
- Shared Workers 共享worker。可被对多个脚本运行在不同的窗体,例如IFrames等, 只要这些workers处于同一域名。共享worker 比专用 worker 稍微复杂一点 — 脚本必须通过活动端口进行通讯。详情请见SharedWorker。
- Service Workers 一般作为web应用程序、浏览器和网络(如果可用)之前的代理服务器。目前比较热的PWA就是基于该技术实现的。当然也不仅仅用于缓存资源二用,作为代理可以用其实现更多的功能,例如访问推送通知和后台同步等。
- Chrome Workers 是一种仅适用于firefox的worker。详情请见ChromeWorker
- 音频 Workers可以在网络worker上下文中直接完成脚本化音频处理.
参考文档
结束语
至此关于web worker 的简单介绍就结束了,前段时间看了下websocket和PWA所以就一起看一下web worker和service worker。抛砖引玉,希望大家共同进步,更多请查看我的实例demo
前端worker之web worker的更多相关文章
- JavaScript多线程之HTML5 Web Worker
在博主的前些文章Promise的前世今生和妙用技巧和JavaScript单线程和浏览器事件循环简述中都曾提到了HTML5 Web Worker这一个概念.在JavaScript单线程和浏览器事件循环简 ...
- Web Worker javascript多线程编程(一)
什么是Web Worker? web worker 是运行在后台的 JavaScript,不占用浏览器自身线程,独立于其他脚本,可以提高应用的总体性能,并且提升用户体验. 一般来说Javascript ...
- Web Worker 初探
什么是Web Worker? Web Worker 是Html5 提出的能够在后台运行javascript的对象,独立于其他脚本,不会影响页面的性能,也不会影响你继续对于页面进行操作.通俗点讲,就是后 ...
- ES6+Webpack 下使用 Web Worker
大家都知道 HTML 5 新增了很多 API,其中就包括 Web Worker,在普通的 js 文件上使用 ES5 编写相关代码应该是完全没有问题了,只需要在支持 H5 的浏览器上就能跑起来. 那如果 ...
- Web Worker 使用教程(转)
转自:http://www.ruanyifeng.com/blog/2018/07/web-worker.html 一.概述 JavaScript 语言采用的是单线程模型,也就是说,所有任务只能在一个 ...
- web Worker基本使用
web worker 使用 web worker 是现代浏览器具有的可以处理密集型任务非常便利的解决方案,众所周知,JavaScript是单线程的(一个JavaScript引擎实例只能占用一个线程,线 ...
- 【转】Web Worker javascript多线程编程(一)
原文:https://www.cnblogs.com/peakleo/p/6218823.html -------------------------------------------------- ...
- Web Worker 使用教程
一.概述 JavaScript 语言采用的是单线程模型,也就是说,所有任务只能在一个线程上完成,一次只能做一件事.前面的任务没做完,后面的任务只能等着.随着电脑计算能力的增强,尤其是多核 CPU 的出 ...
- Web Worker 使用教程【转】
原文:http://www.ruanyifeng.com/blog/2018/07/web-worker.html 一.概述 JavaScript 语言采用的是单线程模型,也就是说,所有任务只能在一个 ...
随机推荐
- 即时通信系统Openfire分析之七:集群配置
前言 写这章之前,我犹豫了一会.在这个时候提集群,从章节安排上来讲,是否合适?但想到上一章<路由表>的相关内容,应该不至于太突兀.既然这样,那就撸起袖子干吧. Openfire的单机并发量 ...
- Guava快速入门
Guava快速入门 Java诞生于1995年,在这20年的时间里Java已经成为世界上最流行的编程语言之一.虽然Java语言时常经历各种各样的吐槽,但它仍然是一门在不断发展.变化的语言--除了语言本身 ...
- win10 uwp 进度条 WaveProgressControl
昨天看到了有个大神做出好看的进度条样式,于是我就去抄袭他的代码,但是发现看不懂,于是本文主要翻译就是大神说这个控件如何做. 本文翻译 https://stackoverflow.com/a/46057 ...
- UWP 绘制图形
UWP图形和wpf变化不多 一般用到有椭圆.长方形.多边形.线 不过如果用的好,可以做出很漂亮的界面 一般使用画图都是使用Shape 类,Shape 类具有一个与其关联的画笔并可以呈现到屏幕,包括 L ...
- PHP 单例模式解析和实战
一.什么是单例模式? 1.含义 作为对象的创建模式,单例模式确保某一个类只有一个实例,而且自行实例化并向整个系统全局地提供这个实例.它不会创建实例副本,而是会向单例类内部存储的实例返回一个引用. 2. ...
- ModelForm
这是一个神奇的组件,通过名字我们可以看出来,这个组件的功能就是把model和form组合起来,对,你没猜错,相信自己的英语水平. 先来一个简单的例子来看一下这个东西怎么用: 比如我们的数据库中有这样一 ...
- C语言位操作
#include <stdio.h> void print(int); int main(void) { int flag = 0xffe4; print(flag); printf(&q ...
- SGU 223 Little Kings(状压DP)
Description 用字符矩阵来表示一个8x8的棋盘,'.'表示是空格,'P'表示人质,'K'表示骑士.每一步,骑士可以移动到他周围的8个方格中的任意一格.如果你移动到的格子中有人质(即'P'), ...
- SimpleDateFormat时间格式化存在线程安全问题
想必大家对SimpleDateFormat并不陌生.SimpleDateFormat 是 Java 中一个非常常用的类,该类用来对日期字符串进行解析和格式化输出,但如果使用不小心会导致非常微妙和难以调 ...
- (转)UML类图与类的关系详解
转载自:http://www.uml.org.cn/oobject/201104212.asp 在画类图的时候,理清类和类之间的关系是重点.类的关系有泛化(Generalization).实现(Rea ...