理解:在数据更新后,dom渲染好,再调用nextTick中的代码。
以前使用this,$nextTick()时,主要是Echarts不渲染问题。网上搜索后,发现用这个可以。
但是为什么要用呢?
1、在created生命周期里调用了echarts渲染函数,导致数据变化时,没有来得及渲染。因为在created期间页面不渲染的。在使用了nextTick()后,等页面渲染更新完后执行回调函数。
nextTick是全局vue的一个函数,在vue系统中,用于处理dom更新的操作。vue里面有一个watcher,用于观察数据的变化,然后更新dom,vue里面并不是每次数据改变都会触发更新dom,而是将这些操作都缓存在一个队列,在一个事件循环结束之后,刷新队列,统一执行dom更新操作。
在vue生命周期的created()钩子函数进行的DOM操作要放在Vue.nextTick()的回调函数中,因为created()钩子函数执行的时候DOM并未进行任何渲染,而此时进行DOM操作是徒劳的,所以此处一定要将DOM操作的JS代码放进Vue.nextTick()的回调函数中。
而与之对应的mounted钩子函数,该钩子函数执行时所有的DOM挂载和渲染都已完成,此时该钩子函数进行任何DOM操作都不会有个问题。