1. 用法: 在数据修改之后立即使用这个方法,获取更新后的DOM。
官方文档解释:
可能你还没有注意到,Vue 在更新 DOM 时是异步执行的。只要侦听到数据变化,Vue 将开启一个队列,并缓冲在同一事件循环中发生的所有数据变更。如果同一个 watcher 被多次触发,只会被推入到队列中一次。这种在缓冲时去除重复数据对于避免不必要的计算和 DOM 操作是非常重要的。然后,在下一个的事件循环“tick”中,Vue 刷新队列并执行实际 (已去重的) 工作。Vue 在内部对异步队列尝试使用原生的
Promise.then
、MutationObserver
和setImmediate
,如果执行环境不支持,则会采用setTimeout(fn, 0)
代替。例如,当你设置
vm.someData = 'new value'
,该组件不会立即重新渲染。当刷新队列时,组件会在下一个事件循环“tick”中更新。多数情况我们不需要关心这个过程,但是如果你想基于更新后的 DOM 状态来做点什么,这就可能会有些棘手。虽然 Vue.js 通常鼓励开发人员使用“数据驱动”的方式思考,避免直接接触 DOM,但是有时我们必须要这么做。为了在数据变化之后等待 Vue 完成更新 DOM,可以在数据变化之后立即使用Vue.nextTick(callback)
。这样回调函数将在 DOM 更新完成后被调用。例如:<div id="example">{{message}}</div>
var vm = new Vue({ el: '#example', data: { message: '123' } }) vm.message = 'new message' // 更改数据 vm.$el.textContent === 'new message' // false Vue.nextTick(function () { vm.$el.textContent === 'new message' // true })
在组件内使用
vm.$nextTick()
实例方法特别方便,因为它不需要全局Vue
,并且回调函数中的this
将自动绑定到当前的 Vue 实例上:Vue.component('example', { template: '<span>{{ message }}</span>', data: function () { return { message: '未更新' } }, methods: { updateMessage: function () { this.message = '已更新' console.log(this.$el.textContent) // => '未更新' this.$nextTick(function () { console.log(this.$el.textContent) // => '已更新' }) } } })
大白话来讲就是,组件里的数据发生了改变,但DOM又没有更新,可我们需要用更新后的DOM来实现一些需求,那么此时就可以(在改变数据后)使用Vue.nextTick(callback),这个callback会在DOM更新后调用执行,以此来实现我们的需求。
我在这里举一个小例子:
<div id = 'app'> {{ a }} </div>
<script>
const vm = new Vue({
el: '#app',
data: {
a: 10
}
})
vm.a = 100
console.log(vm.a) // 100
console.log(vm.$el.innerHTML) // 10
// vm.$el.innerHTML它的值仍然为10,就是DOM异步更新
// 如果需要获取更改后的a的值,可以通过nextTick来实现
vm.$nextTick(() => {
console.log(vm.$el.innerHTML) // 100
})
// 解释说明:nextTick()中的回调函数在DOM更新后执行,取到的数据就是更新后的数据
// html页面显示的数据是 100
</script>