js宏任务和微任务的简单分析

首先我们了解几个概念

1、<单线程>

javaScript 语言的一大特点就是单线程,也就是说,同一个时间只能做一件事。

javaScript 的单线程,与它的用途有关.作为浏览器脚本语言,Javascript 的主要用途是与用户互动,以及操作 DOM. 这决定了它只能是单线程,否则会带来很复杂的同步问题.比如,假定 JavaScript 同时有两个线程,一个线程在某个 DOM 节点上添加内容,另一个线程删除了这个节点,这时浏览器应该以哪个线程为准?这时我们就要了解js的执行机制

2、<JavaScript的执行机制>

 先分析上图:左边是执行域(Call stack),,然后中间的是事件循环(Event Loop)相当于是一个等待区域,右上就是宏任务(包含:setTImeout、setInterval、DOM事件、AJAX请求 ...),右下就是微任务(包含:promise.then、async/await...)---------------所有的宏任务微任务会进入事件循环中,

执行机制:首先执行域会首先按顺序把同步的任务执行完毕,才会执行事件循环的内容,事件循环【宏任务、微任务】中哪个事件触发了,哪个就会排队进入执行域完成加载。

但是事件循环中的宏任务和微任务还会分先后吗?那么谁先谁后呢?我们看一下代码。

 看一下打印结果

 这下就清楚的看到了我们的宏任务微任务的先后顺序了

下图就是宏任务和微任务的执行图

 

 总结:1、要执行宏任务的前提是清空所有的微任务

            2、代码执行流程:同步任务 ==> 事件循环【微任务和宏任务】==> 微任务 ==> 宏任务

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值