直接给一个数组项赋值,Vue 能检测到变化吗?
由于 JavaScript 的限制,Vue 不能检测到以下数组的变动:当你利用索引直接设置一个数组项时,例如: vm.items[indexOfItem] = newValue当你修改数组的长度时,例如: vm.items.length = newLength为了解决第一个问题,Vue 提供了以下操作方法:通过索引来修改数组,使其能成为响应式,解决直接使用赋值不能响应的问题Vue.set(vm.d
·
由于 JavaScript 的限制,Vue 不能检测到以下数组的变动:
当你利用索引直接设置一个数组项时,例如: vm.items[indexOfItem] = newValue
当你修改数组的长度时,例如: vm.items.length = newLength
为了解决第一个问题,Vue 提供了以下操作方法:
通过索引来修改数组,使其能成为响应式,解决直接使用赋值不能响应的问题
Vue.set(vm.data,2,'huanpu','name') 对数组
Vue.$set(vm.data,'K','V') 对对象
- 参数一表示要处理的数组名称。
- 参数二表示要处理的数组的索引。
- 参数三表示要处理的数组的值。
为了解决第二个问题,Vue 提供了以下操作方法:
// Array.prototype.splice
vm.items.splice(newLength)
newLength 就是指的你更新的长度
Vue.set()动态的新增与修改数据,触发视图更新
target:要更改的数据源(可以是对象或者数组)
key:要更改的具体数据(可以是字符串和数字)
value :重新赋的值
用法:向响应式对象中添加一个属性,并确保这个新属性同样是响应式的,且触发视图更新。
例:
data:{
namelist:[
{message:"叶落森",id:"1"},
{message:"姜艳霞",id:"2"},
{message:"姜小帅",id:"3"}
]
},
Vue.set(this.namelist,1,{message:"yeluosen",id:"1"})
注:Vue.set()在methods中也可以写成this.$set()
Vue.set()不光能修改数据,还能添加数据
data:{
items:[
{message:"Test one",id:"1"},
{message:"Test two",id:"2"},
{message:"Test three",id:"3"}
]
},
var itemLen=this.items.length;
Vue.set(this.items,itemLen,{message:"Test add attr",id:itemLen});
更多推荐
已为社区贡献3条内容
所有评论(0)