JS的一道宏任务微任务题目

题目

左边和右边的代码,分别重新渲染了几次 rCount (忽略页面第一次初始化渲染)
在这里插入图片描述

左边

for 循环中 5 次赋给 rCount 值,都是同步代码
每次触发了数据劫持的 setter ,最终会执行 vue 的 nexttick,而 nexttick 的大部分情况是执行一个微任务(Promise)
所以只重新渲染了 1 次

右边

for 循环中产生了 5 个宏任务

宏任务微任务
宏任务1 宏任务2 宏任务3 宏任务4 宏任务5

执行第一个宏任务,给变量赋值,最终会执行 vue 的 nexttick,即产生一个微任务1

宏任务微任务
宏任务2 宏任务3 宏任务4 宏任务5微任务1

微任务优先级高,所以先执行微任务,进行一次渲染
然后再执行宏任务2,产生一个微任务2,再执行微任务,进行一次渲染
依次类推…
一共重新渲染了 5 次

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值