-
Web Worker
-
Web Worker的使用
-
- 主线程中创建Worker线程
-
主线程给Worker线程通信
-
主线程接收Worker线程的消息
-
主线程接收Worker线程发生错误的消息
-
主线程停止Worker线程的工作
-
Worker线程接收来自主线程的消息
-
Worker线程给主线程发送消息
-
Worker线程自我结束
-
Worker线程中加载其它脚本
=========================================================================
由于JavaScript是单线程模型,即所有的任务都在一个线程上完成。显而易见,单线程会给后续发展带来较大的限制。而Web Worker就是为JavaScript提供一个多线程环境,允许JavaScript主线程创建Worker线程(子线程)。
在主线程运行的同时,Worker线程也在执行任务,互不干扰。当Worker线程完成任务时,Worker线程再将数据通过消息通信返回给主线程。
============================================================================
用new操作符 + Worker()构造函数,从而创建一个新的Worker线程。
var worker = new Worker(‘file.js’);
注意:Worker()构造函数的参数是一个脚本文件,必须来源于网络(Worker不能读取本地文件)。该文件就是Worker线程要执行的任务。
在主线程中创建好Worker线程之后,主线程需要给Worker线程发送消息,告诉Worker线程可以执行了,Worker线程才会执行下载的脚本文件。也就是说,即使创建了Worker线程且下载好了任务文件,但是Worker线程没有得到主线程的“命令”,它也是不会执行任务的。
通过postMessage(),主线程给Worker线程通信,“通知”Worker线程可以开始了。
worker.postMessage(“start your job now !”);
postMessage()可以接收对象参数。故也可以写成下面例子所示:
worker.postMessage({
type:“command”,
message:“start your job now !”
});
主线程通过postMessage(),可以给Worker线程发送消息。同时,主线程通过wx.onmessage指定监听函数,接收Worker子线程发回来的消息。
//主线程用onmessage监听Worker子线程发回的消息
worker.onmessage = function(event){
var data = event.data;
console.log(“Data from Worker is :” + data );
doSomething();
}
function doSometiong(){
worker.postMessage(“Done Well!”); //主线程再次发消息给Worker线程
}
主线程除了用worker.onmessage监听Worker线程发回的消息,还需要监听一个比较特殊的信息:错误信息。也就是说当Worker因某种原因不能完成主线程派给它的任务,那么主线程应该知道Worker线程无法完成这个任务。
通过worker.onerror去监听Worker的error事件。
当发生error事件时,事件对象有三个属性,filename,lineno和message。
-
event.filename : 发生错误事件的文件名
-
event.lineno:出错代码行号
-
event.message:完整的出错信息
worker.onerror = function(event){
console.log(“Error file is :” + event.filename )
}
只需调用worker.terminate();就可以停止Worker线程的工作。
worker.terminate();
自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。
深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新
如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
计算机网络
-
HTTP 缓存
-
你知道 302 状态码是什么嘛?你平时浏览网页的过程中遇到过哪些 302 的场景?
-
HTTP 常用的请求方式,区别和用途?
-
HTTPS 是什么?具体流程
-
三次握手和四次挥手
-
你对 TCP 滑动窗口有了解嘛?
-
WebSocket与Ajax的区别
-
了解 WebSocket 嘛?
-
HTTP 如何实现长连接?在什么时候会超时?
-
TCP 如何保证有效传输及拥塞控制原理。
-
TCP 协议怎么保证可靠的,UDP 为什么不可靠?
CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
算法
-
链表
-
字符串
-
数组问题
-
二叉树
-
排序算法
-
二分查找
-
动态规划
-
BFS
-
栈
-
DFS
-
回溯算法
33c2c7e1fa878.png)
CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】
算法
-
链表
-
字符串
-
数组问题
-
二叉树
-
排序算法
-
二分查找
-
动态规划
-
BFS
-
栈
-
DFS
-
回溯算法