事件循环说明
简单来说,vue在修改数据后,视图不会立即更新,而是等同一事件循环中的所有数据变化完成后,再统一进行视图更新
当网页数据更新了,并且在dom中渲染后,自动执行该函数,当项目中你想在改变DOM元素的数据后基于新的dom做点什么,对新的DOM一系列的js操作都需要放进Vue.nextTick()的回调函数中,通俗的理解是:更改数据后当你想立即使用js操作新的视图的时候需要使用它
在使用某个第三方插件时,需要在vue生成的某些dom动态发生变化时,重新应用该插件,也会用到该方法,这个时候就需要在$nextTick的回调函数中执行重新应用插件的方法
注意:nextTick只是dom渲染完成进行操作,但是有时还是没有加载完成的图片,例如:在获取组件的坐标就会出现错误
nextTick和$nextTick区别
1.nextTick(callback):当数据发生变化,更新后执行回调。在下次 DOM 更新循环结束之后执行延迟回调。在修改数据之后立即使用这个方法,获取更新后的 DOM。
2.$nextTick(callback):当dom发生变化,更新后执行的回调。将回调延迟到下次 DOM 更新循环之后执行。在修改数据之后立即使用它,然后等待 DOM 更新。
3.这两个方法没有太大的不同。区别在于:nextTick(callback) 是全局的方法;而 $nextTick(callback) 是回调的 this 自动绑定到调用它的实例上;所以用的更的是$nextTick(callback)!