Vue进阶(八十二):vue 中updated的使用

举报
SHQ5785 发表于 2020/12/30 00:20:16 2020/12/30
【摘要】 由于数据更改导致的虚拟 DOM 重新渲染和打补丁,在这之后会调用该钩子。 无论是组件本身的数据变更,还是从父组件接收到的 props 或者从vuex里面拿到的数据有变更,都会触发虚拟 DOM 重新渲染和打补丁,并在之后调用 updated。 有个值得注意的地方,举例说明: 例子 <template> <div> <div v-for...

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

无论是组件本身的数据变更,还是从父组件接收到的 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>

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23

运行结果

页面首先渲染了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先执行")

 }

  
 
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21

文章来源: shq5785.blog.csdn.net,作者:No Silver Bullet,版权归原作者所有,如需转载,请联系作者。

原文链接:shq5785.blog.csdn.net/article/details/103000580

【版权声明】本文为华为云社区用户转载文章,如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。