监听属性

115 阅读1分钟

监听属性watch:

    1.当被监视的属性发生改变时,回调函数自动调用,进行相关操作
    2.监视的属性必须存在,才能进行监视
    3.监视属性的两种写法:
        (1new 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>