监听属性watch:
1.当被监视的属性发生改变时,回调函数自动调用,进行相关操作
2.监视的属性必须存在,才能进行监视
3.监视属性的两种写法:
(1)new Vue时传入watch配置
(2)通过vm.$watch监视
深度监听
1.vue中的watch默认不监测对象内部值的改变(一层)
2.配置deep:true可以监视对象内部值改变(多层)
备注:
1.vue自身可以监测对象内部属性值的改变,但vue提供的watch默认不可以
2.使用watch时根据数据的具体结构,决定是否采用深度监视
<div id="root">
<h2>今天天气{{info}}</h2>
<button @click="chang">切换天气</button><br><br>
<!-- 绑定事件时@xxx="yyyy"yyy可以是简单的语句 -->
<button @click="isHot=!isHot">切换天气</button><br><br>
<hr>
<h3>a的值是:{{numbers.a}}</h3>
<button @click="numbers.a++">点击a+1</button>
<button @click="numbers.b++">点击a+1</button>
<button @click="numbers={a:666;b:888}">替换numbers</button>
</div>
<script>
Vue.config.productionTip = false
const vm = new Vue({
el: '#root',
data: {
isHot: true,
numbers: {
a: 1,
b: 1,
}
},
computed: {
info() {
return this.isHot ? '热' : '凉'
}
},
methods: {
chang() {
this.isHot = !this.isHot
}
},
watch: {
isHot: {
//初始化时就调用handler
immediate: true,
// 当isHot发生改变时调用handler
handler(newvalue, oldvalue) {
console.log(newvalue, oldvalue)
}
},
// 监视多级结构中某个属性的变化
'numbers.a': {
handler(newvalue, oldvalue) {
console.log('a被改变了', newvalue, oldvalue)
}
},
numders:{
//监视多级结构中所有属性的变化
deep:true,
handler() {
console.log('numbers改变了')
}
}
}
})
// 监听第二种写法(根据用户行为决定监视哪项属性)
vm.$watch('isHot', {
immediate: true,
handler(newvalue, oldvalue) {
console.log(newvalue, oldvalue)
}
})
//简写(当所使用的配置项只有handler时才能使用)
// vm.$watch('isHot',function(newvalue, oldvalue){
// console.log(newvalue, oldvalue)
// })
</script>