微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

vue检测对象和数组的变化分析

在 JavaScript 中对象和数组是引用类型,指向同一个内存空间,如果 prop 是一个对象或数组,在子组件内部改变它会影响父组件的状态。可以直接在子组件修改对象或数组,但是并不会数据改变就会引起变化。

检测对象变化

1、不能检测到对象属性添加删除

rush:js;"> var vm = new Vue({ data:{ data111:{ a = 1 } } })

data111.a = 2;//这个可以引起变化

但data111.b = 2;和vm.b = 2这个不能检测到变化

需要用

rush:js;"> Vue.set(object,key,value)

比如$set(data111,b,2);

或者:

$set(key,value)

比如vm.$set(‘b',2);

检测数组变化

下面两种情况不能检测到变化:

1、直接通过索引设置元素,如arr[0]=12;

2、直接修改数组的长度,如vm.arr.length

Vue.set( object,value )

用法

this.$set(this.arr,12)

原文地址:https://www.jb51.cc/vue/31735.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐