如何简单理解vue的NextTick

它干啥的?

nextTick 中文意思:下一个敲击点。由于vue的响应式是异步的,那么当我们想在所有组件渲染结束后做一下"自己的事情",所以就有了nextTick这个方法。这也就弥补了有一种情况mounted这个生命周期钩子满足不了需求,比如在子组件种操作父组件的dom,子组价的mounted就使不上劲啦。

核心是啥?

1.利用js的事件循环机制,2.源码主要判断当前设备环境支持的异步方法,将回调函数放入数组中,当vue渲染结束,依次执行数组中存放的事件。

解释一下上面的知识点:

① JS 事件循环机制

由于JS是单线程应用,所以按常理代码应该是自上到下依次执行。可是呢实际情况中会遇到异步的情况,比如开了一个定时器,请求了一个接口等。遇到这种情况,JS会把这些事件先放到一个地方存起来。后面继续执行任务,如果再遇到异步任务再存起来,等到从上到下的任务都执行结束,再依次执行存储的异步任务。 异步任务分为宏任务和微任务。放入不同的地方存起来,执行顺序是先微任务再宏任务。

那"循环"体现在哪?

循环就是:当发现当线程的执行的任务结束,如果没有宏任务,取出队列的异步任务执行,然后再走到"当发现当线程的执行的任务结束"。循环至队列中的异步任务结束。

网上下的图,侵权必删

② 方法逻辑和核心源码

逻辑:主要逻辑就是由于js的事件循环机制,当我们想在dom渲染结束之后做一些事情,那么声明一个方法,把要做事情当做参数,然后创建异步任务,利用事件循环再执行那些事情。

核心源码:nextTick 方法参数是一个函数,把这个函数放入callbacks 数组中,优雅降等级判断设备支持的异步方法。优先级为:promise > MutationObserver > setImmediate>setTimout()。flushCallbacks利用当前支持的异步方法执行nextTick存储的任务,

相关推荐
糕冷小美n3 小时前
elementuivue2表格不覆盖整个表格添加固定属性
前端·javascript·elementui
小哥不太逍遥3 小时前
Technical Report 2024
java·服务器·前端
沐墨染3 小时前
黑词分析与可疑对话挖掘组件的设计与实现
前端·elementui·数据挖掘·数据分析·vue·visual studio code
anOnion3 小时前
构建无障碍组件之Disclosure Pattern
前端·html·交互设计
threerocks3 小时前
前端将死,Agent 永生
前端·人工智能·ai编程
问道飞鱼4 小时前
【前端知识】Vite用法从入门到实战
前端·vite·项目构建
爱上妖精的尾巴4 小时前
8-10 WPS JSA 正则表达式:贪婪匹配
服务器·前端·javascript·正则表达式·wps·jsa
Zhencode4 小时前
Vue3响应式原理之ref篇
vue.js
shadow fish5 小时前
react学习记录(三)
javascript·学习·react.js
小疙瘩5 小时前
element-ui 中 el-upload 多文件一次性上传的实现
javascript·vue.js·ui