vue中在data中的对象赋予新的属性是不能响应式的更新数据的。
在这里插入代码片
var vm = new Vue({
el: '#app',
data: {
tempArr: [
{ name: "Tom", age: "11" },
{ name: "Marry", age: "21" },
{ name: "Jack", age: "18" },
],
newArr: []
},
mounted() {
this.handelData();
},
methods: {
showAge(item) {
item.isShow = !item.isShow;
// console.log(item)
},
handelData() {
this.tempArr.forEach(item => {
item.isShow = false;
// Vue.set(item, "isShow", false);
})
console.log(this.tempArr)
}
}
})
我们想实现一个功能: 在点击 对应的 行数时 显示某个字段
点击第一行显示他的年龄, 再次点击隐藏的效果. 由于数据设置是否显示的变量是用对象重写的方式写进去的
this.tempArr.forEach(item => {
item.isShow = false;
})
你会发现你点击后打印出来的数据更新了
但是视图上却没有显示出来.
原因就是:
vue的dom更新是异步的,即当setter操作发生后,指令并不会立马更新,指令的更新操作会有一个延迟,当指令更新真正执行的时候,此时.text属性已经赋值,所以指令更新模板时得到的是新值。
具体流程如下:
self.dataObj = {};发生setter操作
vue监测到setter操作,通知相关指令执行更新操作
self.dataObj[‘text’] = ‘new text’;赋值语句
指令更新开始执行
所以真正的触发更新操作是self.dataObj = {};这一句引起的,所以单看上述例子,具有响应式特性的数据只有dataObj这一层,它的子属性是不具备的。
想要解决也很简单
就是我们在对象重写时用vue提供的方法
Vue.set(“对象”, ‘你的新字段’, “value值”)
脚手架
用 this.$set(“对象”, ‘你的新字段’, “value值”);
插代码检验下效果
<div id="app">
<ul>
<li v-for="item in tempArr" @click="showAge(item)">
{{item.name}}---------<span v-if="item.isShow">{{item.age}}</span></li>
</ul>
</div>
<script>
var vm = new Vue({
el: '#app',
data: {
tempArr: [
{ name: "Tom", age: "11" },
{ name: "Marry", age: "21" },
{ name: "Jack", age: "18" },
],
newArr: []
},
mounted() {
this.handelData();
},
methods: {
showAge(item) {
item.isShow = !item.isShow;
// console.log(item)
},
handelData() {
this.tempArr.forEach(item => {
// item.isShow = false;
Vue.set(item, "isShow", false);
})
console.log(this.tempArr)
}
}
})
很简答的一个demo,在实际工作上难了一天,希望能帮到你们.
当然数据不更新还有其他因素
key值不唯一
依赖外部变量等等.