写点什么

Vue 进阶(八十二):updated 应用详解

发布于: 3 小时前
Vue进阶(八十二):updated 应用详解

一、前言

由于数据更改导致的虚拟 DOM 重新渲染和打补丁,在这之后会调用updated钩子函数。


无论是组件本身的数据变更,还是从父组件接收到的 props 或者从vuex里面拿到的数据有变更,都会触发虚拟 DOM 重新渲染和打补丁,并在之后调用 updated


有个值得注意的地方,举例说明:


例子


<template>    <div>        <div v-for="(item, index) in list" :key="index">{{item}}</div>    </div></template> <script>export default {    data () {        return {            list: [1, 1, 1]        }    },    created () {        setTimeout(_ => {            this.list = [2, 2, 2]        }, 1000)    },    updated () {        console.log('App.vue finish re-render')    }}</script>
复制代码


页面首先渲染了 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 但不渲染页面是不会进的.


data:{   arrData:[1,2,3]  },
updated : function(){
console.log("1==我会先执行");
this.$nextTick(function(){
//在下次DOM更新循环结束之后执行这个回调。在修改数据之后立即使用这个方法,获取更新后的DOM.
console.log("3==我只能等页面渲染完了才会立即执行");
})
console.log("2==我虽然在最后但会比$nextTick先执行")
}
复制代码

三、拓展阅读

发布于: 3 小时前阅读数: 2
用户头像

No Silver Bullet 2021.07.09 加入

岂曰无衣 与子同袍

评论

发布
暂无评论
Vue进阶(八十二):updated 应用详解