首页 前端知识 HTML5(四)——Web Workers,2024最新大厂前端面经

HTML5(四)——Web Workers,2024最新大厂前端面经

2024-05-29 10:05:53 前端知识 前端哥 668 963 我要收藏

2.2 主线程与子线程数据通信:

主线程调用 postMessage() 方法,向 Worker 发消息。postMessage(参数) 方法中参数就是传给 Worker 的数据,这个数据可以是任意格式。

myWorker.postMessage(“你好”)

紧接着 Worker 线程,通过 onmessage 指定监听函数,接收消息。worker.js 代码如下:

this.onmessage = function(res){

console.log(“接收到消息”,res.data)

this.postMessage(“我收到消息了”)

}

worker子进程收到消息之后,可以继续向主进程发送消息,使用 postMessage()。代码如上。

主进程也通过onmessage监听函数接收消息。

myWorker.onmessage = function(res){

console.log(“主线程收到消息:”,res.data)

}

2.3 Worker线程

Worker线程内部,添加 this.onmessage 监听函数,其中 this 是子线程的全局对象,也可以替换成 self,self 代表子线程本身。等同于:

self.onmessage 《=》 this.onmessage

除了使用 self.onmessage 指定监听函数,也可以使用 this.addEventListener() 监听事件对象。上述 worker.js 代码可改为:

//写法一

this.addEventListener(“message”,function(res){

console.log(“res”,res.data)

})

//写法二

addEventListener(“message”,function(res){

this.console.log(“1”,res.data)

})

2.4 错误处理

主线程可以监听Worker是否发生错误,如果发生错误,Worker 会触发主线程的 error 事件。

// 写法一

myWorker.onerror = function(e){

console.log(‘e’,e)

}

//写法二

myWorker.addEventListener(“error”,function(e){

console.log(“e”,e)

})

worker 子线程也可以监听 error 事件。

2.5 关闭 Worker

Worker 比较耗费资源,不应该过度使用,使用完毕之后应该关闭。主线程和子线程都可以关闭。

//主线程关闭

myWorker.terminate()

//子线程关闭

self.close() //方法一

this.close() //方法二

三、同一个网页的Web Worker

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

通常情况下,Worker 载入的是一个单独的 javascript 文件,但是也可以载入与主线程在同一个网页的代码。网页中添加 Worker 脚本,必须注意指定script标签的type属性是一个浏览器不认识的值,否则就会失去意义。如:

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

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

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

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

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

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

前端资料汇总

我一直觉得技术面试不是考试,考前背背题,发给你一张考卷,答完交卷等通知。

首先,技术面试是一个 认识自己 的过程,知道自己和外面世界的差距。

更重要的是,技术面试是一个双向了解的过程,要让对方发现你的闪光点,同时也要 试图去找到对方的闪光点,因为他以后可能就是你的同事或者领导,所以,面试官问你有什么问题的时候,不要说没有了,要去试图了解他的工作内容、了解这个团队的氛围。
找工作无非就是看三点:和什么人、做什么事、给多少钱,要给这三者在自己的心里划分一个比例。
最后,祝愿大家在这并不友好的环境下都能找到自己心仪的归宿。
距。

更重要的是,技术面试是一个双向了解的过程,要让对方发现你的闪光点,同时也要 试图去找到对方的闪光点,因为他以后可能就是你的同事或者领导,所以,面试官问你有什么问题的时候,不要说没有了,要去试图了解他的工作内容、了解这个团队的氛围。
找工作无非就是看三点:和什么人、做什么事、给多少钱,要给这三者在自己的心里划分一个比例。
最后,祝愿大家在这并不友好的环境下都能找到自己心仪的归宿。

转载请注明出处或者链接地址:https://www.qianduange.cn//article/9914.html
标签
评论
会员中心 联系我 留言建议 回顶部
复制成功!