Vue updated 应用详解
        【摘要】  一、前言由于数据更改导致的虚拟 DOM 重新渲染和打补丁,在这之后会调用updated钩子函数。无论是组件本身的数据变更,还是从父组件接收到的 props 或者从vuex里面拿到的数据有变更,都会触发虚拟 DOM 重新渲染和打补丁,并在之后调用 updated。有个值得注意的地方,举例说明:例子<template>    <div>        <div v-for="(item, in...
    
    
    
    一、前言
由于数据更改导致的虚拟 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先执行")
}
 三、拓展阅读
            【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱:
                cloudbbs@huaweicloud.com
                
            
        
        
        
        
        
        
        - 点赞
 - 收藏
 - 关注作者
 
            
           
评论(0)