Vue.nextTick() 有什么作用?实现原理是什么?

发布于 2023-03-15 23:15:34 字数 1388 浏览 83 评论 0

什么是 nextTick

在 vue 里面,数据更新后,我们是无法立马拿到响应数据更新后的 dom 的,nextTick 就是 vue 的 api,如果想要操作 dom,可以通过这个 api 获取

以下是 vue 官方文档

在下次 DOM 更新循环结束之后执行延迟回调。在修改数据之后立即使用这个方法,获取更新后的 DOM。

为什么需要用到 nextTick

浏览器里面频繁操作 dom 会非常影响性能,某个 dom 的宽高变化可能都会引起整个页面的重排重绘

vue.nextTick 就是上述背景的一个产物,我们在更改响应式数据的时候,vue 不会检测到一次数据更新,就去更新一下 dom,它会先有一个 diff 的计算,如果你在真实dom修改之前就想用到真实 dom 的数据,那么可能就需要用到这个 API 了。

nextTick 实现原理

上述下一个 Tick 其实就是下一次事件循环,所以只要是可以放到下一次事件循环的函数都可以用来实现 nextTick,vue 里面采取了以下策略去实现 nextTick

  1. 如果浏览器支持 promise,就用 promise.resolve(fn) 来实现
  2. 否则,如果浏览器支持 MutationObserver,用 MutationObserver
  3. 如果浏览器支持 setImmediate,用 setImmediate
  4. 如果上述都不支持,用 setTimeout 兜底

Vue 2.0 的源码见这 nextTick 源码

自己实现一个不用 mutionObservernextTick

const nextTick = cb => {
  const queueMicrotask =
    typeof queueMicrotask === "function"
      ? queueMicrotask
      : Promise && (cb => Promise.resolve().then(cb))
      ? setImmediate && (cb => setImmediate(cb))
      : cb => setTimout(cb);

  queueMicrotask(cb);
};

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。
列表为空,暂无数据

关于作者

金橙橙

暂无简介

文章
评论
25 人气
更多

推荐作者

櫻之舞

文章 0 评论 0

弥枳

文章 0 评论 0

m2429

文章 0 评论 0

野却迷人

文章 0 评论 0

我怀念的。

文章 0 评论 0

    我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
    原文