当前位置:首页 > VUE

vue nexttick实现

2026-02-10 08:56:53VUE

Vue 中 nextTick 的实现原理

Vue 的 nextTick 是一个用于在下次 DOM 更新循环结束之后执行延迟回调的工具方法。它利用了 JavaScript 的事件循环机制,确保回调在 DOM 更新完成后执行。

核心实现机制

Vue 的 nextTick 实现依赖于微任务(microtask)和宏任务(macrotask)的优先级。在现代浏览器中,优先使用 Promise(微任务),如果不支持则降级到 MutationObserver,最后使用 setTimeout(宏任务)。

const callbacks = []
let pending = false

function flushCallbacks() {
  pending = false
  const copies = callbacks.slice(0)
  callbacks.length = 0
  for (let i = 0; i < copies.length; i++) {
    copies[i]()
  }
}

let timerFunc

if (typeof Promise !== 'undefined') {
  const p = Promise.resolve()
  timerFunc = () => {
    p.then(flushCallbacks)
  }
} else if (typeof MutationObserver !== 'undefined') {
  let counter = 1
  const observer = new MutationObserver(flushCallbacks)
  const textNode = document.createTextNode(String(counter))
  observer.observe(textNode, {
    characterData: true
  })
  timerFunc = () => {
    counter = (counter + 1) % 2
    textNode.data = String(counter)
  }
} else {
  timerFunc = () => {
    setTimeout(flushCallbacks, 0)
  }
}

function nextTick(cb, ctx) {
  let _resolve
  callbacks.push(() => {
    if (cb) {
      try {
        cb.call(ctx)
      } catch (e) {
        handleError(e, ctx, 'nextTick')
      }
    } else if (_resolve) {
      _resolve(ctx)
    }
  })
  if (!pending) {
    pending = true
    timerFunc()
  }
  if (!cb && typeof Promise !== 'undefined') {
    return new Promise(resolve => {
      _resolve = resolve
    })
  }
}

使用场景

nextTick 主要用于在 Vue 更新 DOM 后执行某些操作。例如,在修改数据后立即操作 DOM 元素:

this.message = 'updated'
this.$nextTick(() => {
  // DOM 已更新
  console.log(this.$el.textContent) // 'updated'
})

异步更新队列

Vue 在更新 DOM 时是异步执行的。当数据变化时,Vue 开启一个队列,缓冲在同一事件循环中发生的所有数据变更。如果一个 watcher 被多次触发,只会被推入队列一次。在下一个事件循环“tick”中,Vue 刷新队列并执行实际工作。

nextTick 就是将回调函数添加到这个队列的末尾,确保在 DOM 更新完成后执行。

vue nexttick实现

标签: vuenexttick
分享给朋友:

相关文章

vue实现文章锚点定位

vue实现文章锚点定位

实现文章锚点定位的方法 在Vue中实现文章锚点定位可以通过多种方式完成,以下是几种常见的方法: 使用原生HTML锚点 通过HTML的id属性和<a>标签的href属性实现锚点跳转。在V…

vue 实现单选

vue 实现单选

使用 v-model 绑定单选值 在 Vue 中,可以通过 v-model 绑定单选按钮的值。定义一个响应式数据(如 selectedOption),并将其与单选按钮的 value 属性关联。…

vue实现api

vue实现api

Vue 实现 API 调用 在 Vue 中调用 API 通常涉及使用 axios 或 fetch 发送 HTTP 请求,并结合 Vue 的响应式特性管理数据。以下是常见的实现方式: 安装 axios…

vue 实现长按

vue 实现长按

实现长按功能的基本思路 在Vue中实现长按功能,通常需要监听元素的mousedown或touchstart事件,启动一个计时器。当用户按住元素超过设定的时间阈值时,触发长按回调函数。如果在时间阈值内触…

vue实现反馈

vue实现反馈

Vue 实现反馈功能的方法 在 Vue 中实现反馈功能可以通过多种方式,包括弹窗提示、Toast 消息、表单提交等。以下是几种常见的实现方法。 弹窗反馈 使用 Vue 的组件化特性创建一个弹窗组件…

vue实现vr

vue实现vr

Vue 实现 VR 的方法 Vue 可以与 WebVR 或 WebXR API 结合使用,通过 Three.js、A-Frame 等库实现 VR 效果。以下是几种常见方法: 使用 A-Frame 框…