一、vue的双向数据绑定
js
<ul>
<li v-for="item of list" :key="item.id">
姓名:{{ item.name }}----年龄:{{ item.age }}
</li>
</ul>
<el-button @click="addUser">添加人员</el-button>
data() {
return {
list: [
{ id: 1, name: '小明', age: 18 },
{ id: 2, name: '小华', age: 19 },
{ id: 3, name: '小华' }
]
}
}
方法:
addUser() {
this.list.push({ id: Date.now(), name: 'xx', age: '未知' })
}
如上这段代码,可以看到,定义在data中的list,可以往里面push一条新的数据,数据改变,视图就会更新
二、数据改变,但是不会更新视图的情况
js
<el-button @click="changeUser">改变人员</el-button>
changeUser() {
this.list[2].age = 100
}
在data中定义list的时候,第三项数据并没有age属性,现在,我们来改变它,但是视图并没有任何改变。
原因呢?因为在data中定义list的时候,并没有定义第三项的age属性,那么这个属性就不会经过Object.defineProperty来处理,所以当改变age时,就不会触发视图的更新
三、如何触发视图更新
- 改变整个数组
js
this.list = this.list.map((item, index) => ({
...item,
age: index === 2 ? 100 : item.age
}))
- 使用$set
js
this.$set(this.list[2], 'age', 100)
同样地,如果你想通过length去删除数组的最后一项this.list.length = this.list.length - 1
也是不行的,使用this.$delete(this.list, this.list.length - 1)
便可以。