this.$nextTick(()=>{ }) 将回调函数中的操作放到下一次DOM更新之后执行;类似全局方法vue.nextTick,只不过 this.$nextTick 只作用于调用它的实例。
总的来说,假设我们更改了某个 dom 元素内部的文本,而这时候我们想直接打印这个更改之后的文本是需要 dom 更新之后才会实现的,就像我们把将要打印输出的代码放在 setTimeout(fn, 0) 中。
具体demo如下:
<template>
<button ref="tar"
type="button"
name="button"
@click="testClick">{{content}}</button>
</template>
<script>
export default {
data () {
return {
content: '初始值'
}
}
methods: {
testClick(){
this.content = '改变了的值'
// 这时候直接打印的话,由于dom元素还没更新
// 因此打印出来的还是未改变之前的值
console.log(this.$refs.tar.innerText) // 初始值
}
}
}
</script>
this.$nextTick这个方法作用是当数据被修改后使用这个方法会回调获取更新后的dom再渲染出来。
methods:{
testClick() {
this.content = '改变了的值'
let that = this
this.$nextTick(() => {
// dom元素更新后执行,因此这里能正确打印更改之后的值
console.log(that.$refs.tar.innerText) // 改变了的值
})
}
}