如图:
vue版本:v2.6.11
图中nextTick
函数是存在于源码目录src/core/util/next-tick.js
中
我不明白的点是如我圈出的这个:
如果push了一个回调函数进去callbacks
数组里,然后立马设置pending为true,随后便执行timeFun函数把清空flushCallbacks
这个动作推进微任务队列(或者宏任务队列),那就是说callbacks
只能有一个回调函数???不应该啊,我知道肯定是我理解错了,望各位大神解答
如图:
vue版本:v2.6.11
图中nextTick
函数是存在于源码目录src/core/util/next-tick.js
中
我不明白的点是如我圈出的这个:
如果push了一个回调函数进去callbacks
数组里,然后立马设置pending为true,随后便执行timeFun函数把清空flushCallbacks
这个动作推进微任务队列(或者宏任务队列),那就是说callbacks
只能有一个回调函数???不应该啊,我知道肯定是我理解错了,望各位大神解答
13 回答13k 阅读
8 回答2.7k 阅读
2 回答5.2k 阅读✓ 已解决
5 回答1.3k 阅读
9 回答1.7k 阅读✓ 已解决
6 回答1.5k 阅读
3 回答2.3k 阅读✓ 已解决
pending
就是作为开启异步任务的一个哨兵变量,只开启一个异步任务,添加多个回调函数,然后在此异步队列中批处理清空回调。pending
为true
并不会阻止用户继续添加回调,只是限制不开启多个异步更新队列。