前端事件循环(Event Loop详解)

什么是事件循环(Event Loop)?

一:首先要明确:js的执行机制

1.从上到下依次执行

2.当某一行代码发生错误时,停止执行下面的代码

3.先执行同步代码,在执行异步代码

二:事件循环的执行过程

1.同步代码先执行:调用栈执行后直接出栈

2.异步代码放入回调队列:等待调用栈空后,进入执行

3.宏任务和微任务都属于异步代码,微任务先执行,宏任务后执行

4.微任务在DOM渲染前执行,宏任务在DOM渲染后执行

三:宏任务和微任务的根本区别

1.常见的宏任务有:setTimeout setInterval ajax DOM事件

2.常见的微任务有:promise async/await

3.微任务的执行时间早于宏任务

4.微任务是由es6语法规定的,宏任务是浏览器规定的

四:事件循环的整体流程

1.执行完call stack调用栈中的同步代码

2.执行微任务队列中的微任务代码

3.尝试DOM渲染

4.触发Event Loop 反复询问callbackQueue回调队列中是否还有需要执行的语句,如果有,则放入call stack调用栈中继续执行

五:经典案例

console.log('start');
setTimeout(() => {
    console.log(333);
}); // 安排明天干的活
Promise.resolve('x').then(() => {
    console.log(3);
}).then(() => {
    console.log(4);
}).then(() => {
    console.log(5); // 小任务无限的加 今天干完否则下不了班
    //nodejs 有小任务限制,跳过直接到宏任务
})
console.log('end');

输入结果:start-->end-->3--->4-->5-->333

分析:

1.start和end属于同步代码优先执行

2.promise里的代码也属于同步代码,但.then里的代码属于异步代码中的微任务,稍后执行

3.setTimeout属于异步代码中的宏任务,最后执行

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

敲代码的小辣条

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值