Vue 进阶(八十二):updated 应用详解
一、前言
由于数据更改导致的虚拟 DOM 重新渲染和打补丁,在这之后会调用updated
钩子函数。
无论是组件本身的数据变更,还是从父组件接收到的 props
或者从vuex
里面拿到的数据有变更,都会触发虚拟 DOM
重新渲染和打补丁,并在之后调用 updated
。
有个值得注意的地方,举例说明:
例子
复制代码
页面首先渲染了 3 个 1 的列表,1s 后页面重绘为 3 个 2,并打出'App.vue finish re-render'的日志。
二、注意事项
将created
生命周期函数的setTimeout
函数里的代码改为this.list = [1, 1, 1]
, 会发现还是打出了'App.vue finish re-render'的日志,虽然 list 的值没变,但页面仍然重新渲染了,这是因为 this.list 的指针指向发生了改变。
问:什么时候进updated
方法?答:只有事先设置好的data
变量如 arrData 改变并且要在页面重新渲染{{ arrData }}
完成之后,才会进updated
方法,只改变 arrData 但不渲染页面是不会进的.
复制代码
三、拓展阅读
版权声明: 本文为 InfoQ 作者【No Silver Bullet】的原创文章。
原文链接:【http://xie.infoq.cn/article/83ddebadd80971a14aee9f6cc】。文章转载请联系作者。
评论