Vue中nextTick的简单理解
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vue中nextTick的简单理解相关的知识,希望对你有一定的参考价值。
参考技术A nextTick使用场景:在数据变化之后使用 Vue.nextTick(callback),回调函数将在 DOM 更新完成后被调用。
分析:
Vue 实现响应式是按一定的策略进行 DOM 的更新。且在更新 DOM 时是异步执行的。只要侦听到数据变化,Vue 将开启一个队列,并缓冲在同一事件循环中发生的所有数据变更。如果同一个 watcher 被多次触发,只会被推入到队列中一次。这种在缓冲时去除重复数据对于避免不必要的计算和 DOM 操作是非常重要的。然后,在下一个的事件循环“tick”中,Vue 会刷新队列并执行实际 (已经去重的) 工作。
关于vue中的nextTick深入理解
定义[nextTick、事件循环]
nextTick的由来:
由于VUE的数据驱动视图更新,是异步的,即修改数据的当下,视图不会立刻更新,而是等同一事件循环中的所有数据变化完成之后,再统一进行视图更新。
nextTick的触发时机:
在同一事件循环中的数据变化后,DOM完成更新,立即执行nextTick(callback)内的回调。
应用场景:
需要在视图更新之后,基于新的视图进行操作。
以上出现了事件循环的概念,其涉及到JS的运行机制,包括主线程的执行栈、异步队列、异步API、事件循环的协作,此处不展开之后再总结。大致理解:主线程完成同步环境执行,查询任务队列,提取队首的任务,放入主线程中执行;执行完毕,再重复该操作,该过程称为事件循环。而主线程的每次读取任务队列操作,是一个事件循环的开始。异步callback不可能处在同一事件循环中。
简单总结事件循环:
同步代码执行 -> 查找异步队列,推入执行栈,执行callback1[事件循环1] ->查找异步队列,推入执行栈,执行callback2[事件循环2]...
即每个异步callback,最终都会形成自己独立的一个事件循环。
结合nextTick的由来,可以推出每个事件循环中,nextTick触发的时机:
同一事件循环中的代码执行完毕 -> DOM 更新 -> nextTick callback触发
tips:本文的任务队列、消息队列、异步队列指同一个东西,均指macrotask queue。
watch:{ type: function (val, oldVal) { if(val==2){ Vue.nextTick(function () { //或者用 this.$nextTick $(\'#select\').selectpicker(); }) } } }
以上是关于Vue中nextTick的简单理解的主要内容,如果未能解决你的问题,请参考以下文章