此随笔乃本人学习工作记录,如有疑问欢迎在下面评论,转载请标明出处。
如果对您有帮助请动动鼠标右下方给我来个赞,您的支持是我最大的动力。
Posted huangenai
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue 关于数组和对象的更新相关的知识,希望对你有一定的参考价值。
在日常开发中,我们用的最多的就是 绑定数据
<div v-for="item in data" :key="item.id">
<!-- 内容 -->
</div>
如果你有ng的开发经验,假设 data 你要更新数据了
this.data=res.data;
但是这在vue中 并不会起到作用,DOM并没有触发变化。
vue不是已经实现的实时数据双向绑定,那么model层发生了变化之后,为什么view层没有更新呢???
数组检测更细变异的方法
push()
pop()
shift()
unshift()
splice()
sort()
reverse()
注意事项
由于 javascript 的限制,Vue 不能检测以下变动的数组:
1. this.data[index] = res.data;
2. this.data.length = 0;
正确的操作方式
1.
Vue.$set(
this
.data, 1, {name:"huangenai",age:"22"})
2. vm.items.splice(0)
对象
还是由于 JavaScript 的限制,Vue 不能检测对象属性的添加或删除:
<script> export default { data(){ return { userProfile: { name: ‘Anika‘ } user: { name: "huangenai", age: 12 } } }, mounted() { this.$set(this.userProfile, ‘age‘, 27) this.user = Object.assign({}, this.user, { age: 22, name: "huangenai" }); } } </script>
此随笔乃本人学习工作记录,如有疑问欢迎在下面评论,转载请标明出处。
如果对您有帮助请动动鼠标右下方给我来个赞,您的支持是我最大的动力。
以上是关于vue 关于数组和对象的更新的主要内容,如果未能解决你的问题,请参考以下文章