官方对其的定义
在下次 DOM 更新循环结束之后执行延迟回调。在修改数据之后立即使用这个方法,获取更新后的 DOM
什么意思呢?
我们可以理解成,Vue
在更新 DOM
时是异步执行的。当数据发生变化,Vue
将开启一个异步更新队列,视图需要等队列中所有数据变化完成之后,再统一进行更新。
如果想要在修改数据后立刻得到更新后的DOM
结构,可以使用Vue.nextTick()
第一个参数为:回调函数(可以获取最近的DOM
结构)
第二个参数为:执行函数上下文
- // 修改数据
- vm.message = '修改后的值'
- // DOM 还没有更新
- console.log(vm.$el.textContent) // 原始的值
- Vue.nextTick(function () {
- // DOM 更新了
- console.log(vm.$el.textContent) // 修改后的值
- })
组件内使用 vm.$nextTick()
实例方法只需要通过this.$nextTick()
,并且回调函数中的 this
将自动绑定到当前的 Vue
实例上
- this.message = '修改后的值'
- console.log(this.$el.textContent) // => '原始的值'
- this.$nextTick(function () {
- console.log(this.$el.textContent) // => '修改后的值'
- })
$nextTick()
会返回一个 Promise
对象,可以是用async/await
完成相同作用的事情
- this.message = '修改后的值'
- console.log(this.$el.textContent) // => '原始的值'
- await this.$nextTick()
- console.log(this.$el.textContent) // => '修改后的值'