3分钟带你了解Vue3的nextTick()

8,236次阅读
没有评论

共计 3539 个字符,预计需要花费 9 分钟才能阅读完成。

前言

Vue 实现响应式并不是数据发生变化之后 DOM 立即变化,而是按一定的策略进行 DOM 的更新。简单来说,Vue 在修改数据后,视图不会立刻更新,而是等同一事件循环中的所有数据变化完成之后,再统一进行视图更新,nextTick() 方法就会在这样的 DOM 更新循环结束后调用指定的函数。

概念

在 Vue 3 中 nextTick() 方法的行为和 Vue 2 中基本相似,但它进行了一些优化,以提高性能和稳定性。nextTick() 通过利用微任务(microtask)来确保在 DOM 更新之后执行回调,从而避免在同一事件循环中执行 DOM 操作。简单的理解是,当数据更新了,在 dom 中渲染后,自动执行函数。

方法的使用

nextTick() 的基本使用

// 使用 nextTick() 方法
import {ref, nextTick} from 'vue';

const myValue = ref('initial value');

// 在 DOM 更新后执行回调
nextTick(() => {console.log('DOM 已更新');
});

再 onMounted 中使用

在该示例中,nextTick() 写 onMounted 钩子函数中能确保回调在组件首次挂载后执行,常用于处理与初始渲染相关的逻辑。

// 示例 2: 在 setup() 中使用 nextTick()
import {ref, onMounted, nextTick} from 'vue';

export default {setup() {const myValue = ref('initial value');

    onMounted(() => {
      // 在 DOM 更新后执行回调
      nextTick(() => {console.log('DOM 已更新');
      });
    });

    return {myValue,};
  },
};

nextTick() 的异步执行

nextTick() 中的回调函数是异步执行的。这意味着即使在同一事件循环中调用多次 nextTick(),它们的回调函数也会按照调用顺序异步执行。

// 示例 3: nextTick() 的异步执行
import {ref, nextTick} from 'vue';

const myValue = ref('initial value');

// 在 DOM 更新后执行第一个回调
nextTick(() => {console.log('第一个回调执行');
});

// 在 DOM 更新后执行第二个回调
nextTick(() => {console.log('第二个回调执行');
});

nextTick() 的使用场景

在数据变化后等待 DOM 更新

这是 nextTick() 最常见的用途。例如,你可能更改了一个数据属性,该属性控制一个元素的可见性。然后你可能想要等待 DOM 更新以便可以获取该元素的新的宽度或高度。在这种情况下,你可以使用 nextTick() 来确保你的代码在 DOM 更新后执行。

  
  

在创建或销毁组件后等待 DOM 更新

当创建或销毁 Vue 组件时,Vue 需要时间来更新 DOM。如果你需要立即访问新创建或已销毁的 DOM 元素,你可能会遇到问题,因为 DOM 可能还没有更新。在这种情况下,你可以使用 nextTick() 来确保你的代码在 DOM 更新后执行。

  
  

在异步更新队列中插入自己的回调

Vue 在更新 DOM 时是异步执行的。只要侦听到数据变化,Vue 将开启一个队列,并缓冲在同一事件循环中发生的所有数据变更。如果同一个 watcher 被多次触发,只会被推入到队列中一次。这种在缓冲时去除重复数据,对于避免不必要的计算和 DOM 操作是非常重要的。然后,在下一个的事件循环“tick”中,Vue 刷新队列并执行实际 (已去重的) 工作。Vue 在内部对异步队列尝试使用原生的 Promise.then、MutationObserver 和 setImmediate,如果执行环境不支持,则会采用 setTimeout(fn, 0) 代替。你可以通过 nextTick() 将回调延迟到下次 DOM 更新循环之后执行。在修改数据之后立即使用它,然后等待 DOM 更新。

处理大量数据

在处理大量数据时,Vue.js 可能会变得有点慢,因为它需要时间来处理所有的数据并更新 DOM。在这种情况下,你可能想要使用 nextTick() 来分批处理数据,以便给浏览器一些时间来更新 DOM。这可以提高应用程序的性能,并减少用户在处理大量数据时的等待时间。

  
  

与第三方库集成

有些第三方库可能需要直接操作 DOM,或者需要在 DOM 更新后才能正确工作。在这种情况下,你可以使用 nextTick() 来确保在集成这些库时 DOM 已经更新。例如,你可能想要在使用一个 JavaScript 动画库之前等待 DOM 更新,以确保动画在正确的元素上运行。或者你可能想要在使用一个需要测量元素尺寸或位置的库之前等待 DOM 更新。在这些情况下,nextTick() 可以帮助你确保 DOM 已经更新并准备好与第三方库集成。

  
  

原文地址: 3 分钟带你了解 Vue3 的 nextTick()

    正文完
     0
    Yojack
    版权声明:本篇文章由 Yojack 于2024-10-29发表,共计3539字。
    转载说明:
    1 本网站名称:优杰开发笔记
    2 本站永久网址:https://yojack.cn
    3 本网站的文章部分内容可能来源于网络,仅供大家学习与参考,如有侵权,请联系站长进行删除处理。
    4 本站一切资源不代表本站立场,并不代表本站赞同其观点和对其真实性负责。
    5 本站所有内容均可转载及分享, 但请注明出处
    6 我们始终尊重原创作者的版权,所有文章在发布时,均尽可能注明出处与作者。
    7 站长邮箱:laylwenl@gmail.com
    评论(没有评论)