侦听器的基本结构
<script>
// 【侦听器】
// 作用:用来侦听数据有没有变化,一旦有变化就调用函数。
// 语法: 在和data、methods这些平级的位置写一个 watch
new Vue({
el:'',
data:{},
methods:{},
// 侦听器
watch:{
// 参数一:改变后的值。
// 参数二:改变前的值。
要侦听的数据(newValue,oldValvue){
}
}
})
</script>
侦听器的基本使用
<div id="app">
<button @click="msg='哈哈哈哈哈'">修改msg的值</button>
<p>{ {msg}}</p>
</div>
<script src="./vue.js"> </script>
<script>
new Vue({
el:'#app',
data:{
msg:'嘎嘎嘎嘎'
},
//写侦听器的地方
watch:{
// 侦听器的数据变化
// 基本数据类型,这两个参数有意义
msg(newValue,oldValue){
// 侦听到数据变化之后,需要完成的行为
console.log('数据改变了',newValue,oldValue);
}
}
})
</script>
侦听器在数组的使用
<div id="app">
<ul>
<li v-for="item in list">{ {item}}</li>
</ul>
<button @click="list.push('喜羊羊')">添加一个项</button>
</div>
<script src="./vue.js"></script>
<script>
new Vue({
el:'#app',
data:{
list:['小黄很没用','小钟很事多','小卢恋爱脑']
},
watch:{
list(newValue,oldVaule){
console.log('数据的改变了',newValue,oldVaule,);
}
}
})
</script>
侦听器2
【对数组进行侦听】
数组是应用类型,存在比较复杂的侦听规则。
从理论上说,修改一个数组的内容,比如修改数组中某个元素的值,或者给数组添加新的元素,都不会修改数组本身的地址。
为此.Vue.is对数组做了特殊处理,使得使用标准的数组操作方法对数组所做的修改,都可以被侦听到。
1.Vue不能检测以下数组的变动:
a.当你利用索引值直接设置一个数组时,例如:vm.items[index0fItem] = newValue
b.当你修改数组的长度时,例如:vm.items.length = newlength
2.使用标准方法修改数组可以被侦听到
push() 尾部添加 pop()尾部删除
unshift()头部添加
shift()头部删除
splice()删除、添加、替换
sort()排序
reverse()逆序
(Vue将被侦听的数组的变更方法进行了包裹,所以它们也将会触发视图更新,以上就是被包裹的方法。)
<div id="app">
<button @click="list.pop()">删除一个项</button>
<button @click="list.push('喜羊羊')">添加一个项</button>
<ul>
<li v-for="item in list">{
{item}}</li>
</ul>
</div>
<script src="./vue.js"></script>
<script>
new Vue({
el:'#app',
data:{
list:['小黄很没用','小钟很事多','小卢恋爱脑']
},
watch:{
// 复杂数据类型,这两个参数没有意义,因为地址没变
// 所以复杂类型中,一般不会写这两个参数,因为这两个参数的值是一样的,就是写也只写一个。
list(newValue,oldVaule){
console.log('数据的改变了',newValue,oldVaule,);
}
}
})
</script>
侦听器3
watch:{
这种写法侦听不到obj对象内部属性的变化,
只能侦听到obj对象指向的变化。
obj(){
console.log('obj变化了');
},
如果想侦听到对象里属性的变化.
侦听obj里name的变化(要记得加引号)
"obj.name"(){
console.log('name变化了');
},
可是这样写只能侦听一个属性。
如果希望侦听到对象里所有属性的变化,就要开启深度侦听。
obj:{
/当有变化会调用的函数
handler(){
console.log('obj的属性变化了');
},
开启深度侦听
deep:true,
号要不要当前页面一打开就立即调用handler函数。
给true表示立即调用,默认是flase。(代表只有改动了才调用
immediate:true
}
}
<!-- 对对象进行侦听 -->
<div id="app">
<p>{
{ obj.name }} --- {
{ obj.age }} --- {
{ obj.height }}</p >
<button @click = "obj.name ='rose'">修改obj的name属性</button>
<button @click = "obj.age = 30">修改obj的age属性</button>
<button @click = "obj = {name:'andy',age:99} ">修改obj的指向</button>
</div>
<script src="./vue.js"></script>
<script>
new Vue({
el:'#app',
data:{
obj:{
name:'小黄玩不过植物大战僵尸',
age:40,
height:160
}
},
watch:{
obj:{
handler(){
console.log('obj的属性变化了');
},
}
}
})
</script>
侦听器4
在数组中使用侦听器总结:
1.彻底替换为一个新数组,那么可以被侦听到。
2.如果使用了push()等标准的数组操作方法,那么可以被侦听到。
3.如果直接修改数组的元素,那么无法被侦听到。
(解决方法:使用$set(()方法修改元素的值。Vue3语法。)
不要使用length属性来修改数组长度,而改用其他标准方法显示数组长度的变化。
<div id="app">
<button @click="list.pop()">删除一个项</button>
<button @click="list.push('喜羊羊')">添加一个项</button>
<!-- 利用索引值改变数组时,不能被侦听到 -->
<button @click="list[0]='没用'">修改第一项</button>
<button @click="list.splice(1,0,'小彭很厉害')">第二添加</button>
<ul>
<li v-for="item in list">{
{item}}</li>
</ul>
</div>
<script src="./vue.js"></script>
<script>
new Vue({
el:'#app',
data:{
list:['小黄很没用','小钟很事多','小卢恋爱脑']
},
watch:{
// 复杂数据类型,这两个参数没有意义,因为地址没变
// 所以复杂类型中,一般不会写这两个参数,因为这两个参数的值是一样的,就是写也只写一个。
list(){
console.log('数据的改变了');
}
}
})
</script>