javascript的eventloop相关知识

本系列文章是本人学习相关知识时所积累的笔记,以记录自己的学习历程,也为了方便回顾知识;故文章内容较为随意简练,抱着学习目的来的同学务必转移他处,以免我误人子弟~

今天看到一段js深拷贝的代码

// MessageChannel
function structuralClone(obj) {
  return new Promise(resolve => {
    const {port1, port2} = new MessageChannel();
    port2.onmessage = ev => resolve(ev.data);
    port1.postMessage(obj);
  });
}

var obj = {a: 1, b: {
    c: b
}}
// 注意该方法是异步的
// 可以处理 undefined 和循环引用对象
(async () => {
  const clone = await structuralClone(obj)
})()

使用的是我前所未闻的 MessageChannel 对象接口
一搜索发现了 micro taskmacro task 等概念
在搜索发现了 javascript 的 eventloop
eventloop 倒是经常听到,今天就来一探究竟。。。

参考资料
MessageChannel是什么,怎么使用?
阮一峰:什么是 Event Loop?
阮一峰:JavaScript 运行机制详解:再谈Event Loop
Javascript 基础夯实——理解 Event Loop、Micro Task & Macro Task

所以严格意义上来讲,javascript 不是单线程的???

eventloop 实现了 javascript 的异步模式

主任务(同步代码) ——> micro task(Promise) ——> 渲染视图 ——> macro task(setTimeout)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值