在日常开发中,我们用的最多的就是 绑定数据
<div v-for=\"item in data\" :key=\"item.id\">
<!-- 内容 -->
</div>
如果你有ng的开发经验,假设 data 你要更新数据了
this.data=res.data;
但是这在vue中 并不会起到作用,DOM并没有触发变化。
vue不是已经实现的实时数据双向绑定,那么model层发生了变化之后,为什么view层没有更新呢???
看官网 这里才发现 深入响应式原理 列表渲染
vue 关于数组和对象的更新
数组检测更细变异的方法
push()
pop()
shift()
unshift()
splice()
sort()
reverse()
注意事项
由于 的限制,Vue 不能检测以下变动的数组:
- this.data[index] = res.data;
- this.data.length = 0;
正确的操作方式
- Vue.$set(this.data, 1, {name:\"huangenai\",age:\"22\"})
- vm.items.splice(0)
对象
还是由于 的限制,Vue 不能检测对象属性的添加或删除:
< >
export default {
data(){
return {
userProfile: {
name: \'Anika\'
}
user: {
name: \"huangenai\",
age: 12
}
}
},
mounted() {
this.$set(this.userProfile, \'age\', 27)
this.user = .assign({}, this.user, {
age: 22,
name: \"huangenai\"
});
}
}
</ >
Vue提供了如下的数组的变异方法,可以触发视图更新
push()
pop()
shift()
unshift()
splice()
sort()
reverse()
继续阅读与本文标签相同的文章
上一篇 :
一文快入VBA——一个VBA数据处理小程序的解析
下一篇 :
深度学习的核心:掌握训练数据的方法
-
史上最详细Java内存区域讲解
2026-05-19栏目: 教程
-
Hystrix Dashboard:断路器执行监控
2026-05-19栏目: 教程
-
AGV为什么要选择视觉导航
2026-05-19栏目: 教程
-
《Absolute Java 中文版》| 每日读本书
2026-05-19栏目: 教程
-
汽车圈微信聊天记录大曝光
2026-05-19栏目: 教程
