前端面经 关于Web Worker,经典实战教程

  • Web Worker

  • Web Worker的使用

    • 主线程中创建Worker线程
  • 主线程给Worker线程通信

  • 主线程接收Worker线程的消息

  • 主线程接收Worker线程发生错误的消息

  • 主线程停止Worker线程的工作

  • Worker线程接收来自主线程的消息

  • Worker线程给主线程发送消息

  • Worker线程自我结束

  • Worker线程中加载其它脚本

Web Worker

=========================================================================

由于JavaScript是单线程模型,即所有的任务都在一个线程上完成。显而易见,单线程会给后续发展带来较大的限制。而Web Worker就是为JavaScript提供一个多线程环境,允许JavaScript主线程创建Worker线程(子线程)。

在主线程运行的同时,Worker线程也在执行任务,互不干扰。当Worker线程完成任务时,Worker线程再将数据通过消息通信返回给主线程。

Web Worker的使用

============================================================================

主线程中创建Worker线程


用new操作符 + Worker()构造函数,从而创建一个新的Worker线程。

var worker = new Worker(‘file.js’);

注意:Worker()构造函数的参数是一个脚本文件,必须来源于网络(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 !”

});

主线程接收Worker线程的消息


主线程通过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线程发生错误的消息


主线程除了用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线程的工作


只需调用worker.terminate();就可以停止Worker线程的工作。

worker.terminate();

Worker线程接收来自主线程的消息


自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数前端工程师,想要提升技能,往往是自己摸索成长或者是报班学习,但对于培训机构动则几千的学费,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Web前端开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。
img
img
img
img
img
img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上前端开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录大纲截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且后续会持续更新

如果你觉得这些内容对你有帮助,可以添加V获取:vip1024c (备注前端)
img

计算机网络

  • HTTP 缓存

  • 你知道 302 状态码是什么嘛?你平时浏览网页的过程中遇到过哪些 302 的场景?

  • HTTP 常用的请求方式,区别和用途?

  • HTTPS 是什么?具体流程

  • 三次握手和四次挥手

  • 你对 TCP 滑动窗口有了解嘛?

  • WebSocket与Ajax的区别

  • 了解 WebSocket 嘛?

  • HTTP 如何实现长连接?在什么时候会超时?

  • TCP 如何保证有效传输及拥塞控制原理。

  • TCP 协议怎么保证可靠的,UDP 为什么不可靠?

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

算法

  • 链表

  • 字符串

  • 数组问题

  • 二叉树

  • 排序算法

  • 二分查找

  • 动态规划

  • BFS

  • DFS

  • 回溯算法


    33c2c7e1fa878.png)

CodeChina开源项目:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

算法

  • 链表

  • 字符串

  • 数组问题

  • 二叉树

  • 排序算法

  • 二分查找

  • 动态规划

  • BFS

  • DFS

  • 回溯算法

  • 23
    点赞
  • 28
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值