vue中的nexttick

x33g5p2x  于2022-02-24 转载在 Vue.js  
字(0.7k)|赞(0)|评价(0)|浏览(460)

我们了解nexttick之前,我们先来看一个例子。

我们先要每一次都在点击按钮的时候,都进行字符串的累加操作,并且在该函数中计算该字符串所占的高度offsetHeight,但是我们当进行第一次点击的时候,此时打印的结果不符合,因为内容不为空,但是打印出的高度仍然显示为0
一、思考(会出现上述情况)
因为当我们进行改变数据的时候,此时会进行执行三个过程
1、执行watch函数
2、更新dom元素
3、执行相关的生命周期函数
因为我们在addString方法下面直接打印出offsetHeight的值,这一过程为同步执行。但是当我们执行this.addName += "哈哈哈哈"时,其后面执行的三个步骤均为异步执行的,并且为微任务,将其压入微任务队列中。所以我们打印offsetHeight时,并没有更新DOM,所以仍然拿到原来的值。
二、解决办法
我们再执行this.addName += "哈哈哈哈",会立即产生微任务放入微任务队列,此时如果我们将打印offsetHeight变为微任务,放入微任务队列中,此时便会打印出我们想要的正确结果。在vue中,给我们提供了nexttick来解决。
三、nexttick
nexttick:将回调推迟到下一个 DOM 更新周期之后执行。在更改了一些数据以等待 DOM 更新后立即使用它。
nexttick会将其中的回调函数放入微任务队列中。

四、nexttick代码

如上图所示,nextTick返回一个promise.then,对于这样一个结果,我们会将其放入微任务队列中。

相关文章