1. vue会监视data中所有层次的数据,但是vue提供的watch默认只监视一层
2. 如何检测对象中的数据?
通过setter实时监测,必须的在new Vue时就要传入要检测的数据
(1) 对象中后追加的属性,Vue默认不做响应式处理
(2) 如果需要后加的属性也要做响应式,可以使用下面这两个API
Vue.set(target,propertyName/index,value)或者
vm.$set(target,propertyName/index,value)
3.如何检测数组中的数据?
通过包裹数组更新元素的方法实现,本质就是做了两件事:
(1)通过原生对应的方法对数组进行更新
(2)重新解析模板,进行页面更新
想要修改数组中的元素可以使用一下方法,下面这个方法都被Vue包裹
<<< push最后添加,
pop最后删除,
shift删除第一个,
unshift数组最前面加一个,
splice在特定位置增删改,
sort排序,
reverse反转 >>>
4.注意!!!
Vue.set(target,propertyName/index,value)或者
vm.$set(target,propertyName/index,value)不可以在Vue根目录添加属性
<div class="box">
<h3>姓名:{{student.name}}</h3>
<h3>年龄:{{student.age}}</h3>
<h3 v-if="student.sex">性别:{{student.sex}}</h3>
<h2>爱好:</h2>
<ul>
<li v-for="h in student.hobby">
{{h}}
</li>
</ul>
<hr>
<h2>朋友们</h2>
<ul>
<li v-for="(f,index) in student.friends">
{{f.name}}---{{f.age}}
</li>
</ul>
<button @click="student.age++">年龄+1</button><br>
<button @click="addSex()">添加性别属性</button>
<button @click="student.sex = '女'" v-show="student.sex">修改性别属性</button>
<br><button @click.once="addFriend()">在列表首位添加一个朋友</button><br>
<button @click="updataFristFriend()">第一位朋友的名字改为张三</button><br>
<button @click.once="addHobby()">添加一个爱好</button><br>
<button @click="updataFirstHobby()">第一个爱好修改为学习</button><br>
<button @click="removeHobby()">过滤掉抽烟爱好</button><br>
</div>
</body>
<script>
const vm = new Vue({
el: '.box',
data: {
student: {
name: 'tom',
age: 22,
friends: [
{ name: 'tady', age: 18 },
{ name: 'tiga', age: 25 },
],
hobby: ['抽烟', '喝酒', '烫头']
},
},
methods: {
addSex() {
this.$set(this.student, 'sex', '男');
// Vue.set(this.student, 'sex', '男')
},
addFriend() {
// 在数组最前面添加
this.student.friends.unshift({ name: 'chin', age: 22 });
},
updataFriend() {
// 虽然不能直接修改数组中的元素,但是元素是对象,对象中的属性是可以修改的
this.student.friends[0].name = '张三';
},
addHobby() {
this.student.hobby.push('写代码');
},
updataFirstHobby() {
// 数组不能直接赋值
// 从索引第0个开始删除1个,然后添加一个
this.student.hobby.splice(0, 1, '学习');
// Vue.set不仅可以添加,还可以修改 下面这两个都是可以的
// Vue.set(this.student.hobby, 0, '学习');
// this.$set(this.student.hobby, 0, '学习')
},
removeHobby() {
this.student.hobby = this.student.hobby.filter((h) => {
return h !== "抽烟";
})
}
}
})
</script>