先自我介绍一下,小编浙江大学毕业,去过华为、字节跳动等大厂,目前阿里P7
深知大多数程序员,想要提升技能,往往是自己摸索成长,但自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!
因此收集整理了一份《2024年最新Web前端全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友。
既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,涵盖了95%以上前端开发知识点,真正体系化!
由于文件比较多,这里只是将部分目录截图出来,全套包含大厂面经、学习笔记、源码讲义、实战项目、大纲路线、讲解视频,并且后续会持续更新
如果你需要这些资料,可以添加V获取:vip1024c (备注前端)
正文
注意: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();
主线程可以通过worker.postMessage(),将消息传递给子线程Worker线程。那在Worker线程中,就会触发messge事件。为了处理来自主线程的信息,则需要创建一个onmessage去监听信息。
self.onmessage = function(event){
var data = event.data;
// doSomething
}
除了用onmessage去指定监听函数,也可以通过addEventListener()来指定监听函数,具体代码如下:
self.addEventListener(‘message’,function(e){
//doSomething;
},false)
//或者
this.addEventListener(‘message’,function(e){
//doSomething
},false)
//也可以
addEventListener(‘message’,function(e){
//doSomething
},false)
因为在Worker线程中,self和this都是指向Worker子线程自身,也就是全局对象。所以第三种不写self和this也是可以的。
Worker线程也需要向主线程发送消息,用self.postMessage()即可
TCP协议
- TCP 和 UDP 的区别?
- TCP 三次握手的过程?
- 为什么是三次而不是两次、四次?
- 三次握手过程中可以携带数据么?
- 说说 TCP 四次挥手的过程
- 为什么是四次挥手而不是三次?
- 半连接队列和 SYN Flood 攻击的关系
- 如何应对 SYN Flood 攻击?
- 介绍一下 TCP 报文头部的字段
- TCP 快速打开的原理(TFO)
- 说说TCP报文中时间戳的作用?
- TCP 的超时重传时间是如何计算的?
- TCP 的流量控制
- TCP 的拥塞控制
- 说说 Nagle 算法和延迟确认?
- 如何理解 TCP 的 keep-alive?
浏览器篇
- 浏览器缓存?
- 说一说浏览器的本地存储?各自优劣如何?
- 说一说从输入URL到页面呈现发生了什么?
- 谈谈你对重绘和回流的理解
- XSS攻击
- CSRF攻击
- HTTPS为什么让数据传输更安全?
- 实现事件的防抖和节流?
- 实现图片懒加载?
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!
68255894)]
网上学习资料一大堆,但如果学到的知识不成体系,遇到问题时只是浅尝辄止,不再深入研究,那么很难做到真正的技术提升。
需要这份系统化的资料的朋友,可以添加V获取:vip1024c (备注前端)
[外链图片转存中…(img-TcMZDsgu-1713068255895)]
一个人可以走的很快,但一群人才能走的更远!不论你是正从事IT行业的老鸟或是对IT行业感兴趣的新人,都欢迎加入我们的的圈子(技术交流、学习资源、职场吐槽、大厂内推、面试辅导),让我们一起学习成长!