如何简单理解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存储的任务,

相关推荐
加个鸡腿儿16 分钟前
从"包裹器"到"确认按钮"——一个组件的三次重构
前端·vue.js·设计模式
Kel19 分钟前
深入 OpenAI Node SDK:一个请求的奇幻漂流
javascript·人工智能·架构
子兮曰22 分钟前
AI写代码坑了90%程序员!这5个致命bug,上线就炸(附避坑清单)
前端·javascript·后端
猪八宅百炼成仙28 分钟前
PanelSplitter 组件:前端左右布局宽度调整的实用解决方案
前端
BUG胡汉三31 分钟前
自建在线文档编辑服务:基于 Collabora CODE + Spring Boot + Vue 3 的完整实现
vue.js·spring boot·后端·在线编辑
锋利的绵羊44 分钟前
【解决方案】微信浏览器跳出到浏览器打开、跳转到app,安卓&ios
前端
终端鹿1 小时前
Vue3 核心 API 补充解析:toRef / toRefs / unref / isRef
前端·javascript·vue.js
刘宇琪1 小时前
如何有效缓解大语言模型生成内容中的事实性错误(幻觉)
前端
英俊潇洒美少年1 小时前
vue的事件循环
前端·javascript·vue.js
GISer_Jing1 小时前
Next.js全栈开发实战与面试指南
前端·javascript·react.js