第一章 Vue核心 第九节 监视属性

监视属性watch:
    1.当监视的属性变化时,回调函数自动调用,进行相关操作
    2.监视的属性必须存在,才能进行监视
    3.监视的两种方法:
        (1).new Vue时传入watch配置
        (2).通过vm.$watch监视

    4.深度监视:
        (1).Vue中的watch默认不监视对象内部值的改变(一层);
        (2).配置deep:true可以监测对象内部值的改变(多层)。
        备注:
            (1).Vue自身可以监测对象内部值的改变,但Vue提供的watch默认不可以;
            (2).使用watch时根据数据的具体结构,决定是否采用深度监视。

computed与watch之间的区别:
    1.computed能完成的功能,watch都能完成
    2.watch能完成的功能,computed不一定能完成,例如:watch可以进行异步操作
两个重要的小原则:
    1.所有被Vue管理的函数,最好写成普通函数,这样this的指向才是vm 或 组件实例对象。
    2.所有不被Vue所管理的函数(定时器函数的回调函数、ajax的回调函数、Promise的回调函数),最好写成箭头函数,
      这样this的指向才是vm 或 组件实例对象

示例代码:

复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>监视(侦听)属性-天气案例</title>
    <!--引入Vue-->
    <script src="../lib/vue.js"></script>
</head>
<body>
    <!--准备好一个容器-->
    <div id="root">
        <h2>今天天气很{{info}}</h2>
        <!-- @xxx='yyy' yyy可以是一个简单的js语句 isHot = !isHot; -->
        <button @click="change">切换天气</button>
        <hr/>
        <h3>a的值是:{{numbers.a}}</h3>
        <button @click="numbers.a++;">点我让a+1</button>
        <h3>b的值是:{{numbers.b}}</h3>
        <button @click="numbers.b++;">点我让b+1</button>
    </div>

    <script type="text/javascript">
        Vue.config.productionTip = false;

        const vm = new Vue({
            el:'#root',
            data:{
                isHot:true,
                numbers:{
                    a:1,
                    b:2
                }
            },
            methods:{
                change(){
                    this.isHot = !this.isHot;
                }
            },
            computed:{
                info(){
                    return this.isHot ? '炎热':'凉爽';
                }
            },
            //监视属性的第一种写法
            watch: {
                //正常写法
                // isHot: {
                //     //immediate: true,//初始化时让handler调用一下
                //     //handler在isHot发生变化时调用
                //     handler(newValue, oldValue) {
                //         console.log('watch - isHot被修改了', newValue, oldValue);
                //     }
                // },
                // info: {
                //     //immediate: true,//初始化时让handler调用一下
                //     //handler在isHot发生变化时调用
                //     handler(newValue, oldValue) {
                //         console.log('watch - info被修改了', newValue, oldValue);
                //     }
                // },
                //简写  不能设置配置项
                isHot(newValue, oldValue){
                    console.log('watch - isHot被修改了', newValue, oldValue);
                },
                info(newValue, oldValue){
                    console.log('watch - info被修改了', newValue, oldValue);
                },
                // 'numbers.a':{
                //     handler(){
                //         console.log('a的值加一');
                //     }
                // }
                numbers:{
                    deep:true,
                    handler(){
                        console.log('numbers被改变了');
                    }
                },
            }
        });

        //监视属性的第二种写法
        //正常写法
        // vm.$watch('isHot',{
        //     immediate:true,//初始化时让handler调用一下
        //     //handler在isHot发生变化时调用
        //     handler(newValue,oldValue){
        //         console.log('isHot被修改了',newValue,oldValue);
        //     }
        // });
        // vm.$watch('info',{
        //     immediate:true,//初始化时让handler调用一下
        //     //handler在isHot发生变化时调用
        //     handler(newValue,oldValue){
        //         console.log('info被修改了',newValue,oldValue);
        //     }
        // });
        //简写  不能设置配置项
        // vm.$watch('isHot',function(newValue,oldValue){
        //     console.log('isHot被修改了',newValue,oldValue);
        // });
        // vm.$watch('info',function(newValue,oldValue){
        //     console.log('info被修改了',newValue,oldValue);
        // });
    </script>
</body>
</html>
复制代码

本文作者:何以之

本文链接:https://www.cnblogs.com/serendipity-echo/articles/15407944.html

版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。

posted @   何以之  阅读(108)  评论(0编辑  收藏  举报
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
收起
  1. 1 残酷游戏 卫兰
  2. 2 明知做戏 吴雨霏
  3. 3 你,好不好? 周兴哲
  4. 4 我可以 蔡旻佑
  5. 5 云烟成雨 房东的猫
  6. 6 说散就散 JC 陈咏桐
  7. 7 我配不上你 夏天Alex
  8. 8 不再联系 夏天Alex
  9. 9 等我先说 夏天Alex
  10. 10 我知道他爱你 夏天Alex
  11. 11 多想在平庸的生活拥抱你 隔壁老樊
  12. 12 这一生关于你的风景 隔壁老樊
  13. 13 我曾 隔壁老樊
  14. 14 关于孤独我想说的话 隔壁老樊
  15. 15 过客 周思涵
  16. 16 备爱 周思涵
  17. 17 嚣张 en
  18. 18 海口 后弦
明知做戏 - 吴雨霏
00:00 / 00:00
An audio error has occurred, player will skip forward in 2 seconds.

作词 : 夏至(蔡冕丽)

作曲 : 方文良

编曲 : 吴国恩

等你的汽水喝一半给你加片薄冰

等你的桌面满泄我总会打理重整

不想纯情

不够聪明

你未发现我的身影

得我帮你依照编码整理家里电影

只会得我一个帮你选购喜爱铃声

天天如常

估你心情

等一个眼神求证

一闪擦过如流星

怎么我为我做过的感到惊怕

就像爱吗我也不肯定恐怕

我以为存在吗

千变万化

从来不肯开口可相信吗

离谱吗

请你不要阻我喜欢你

明明是爱但你未说话你扮作闪避

这个沉默冷静的你亳无办法处理

其实我亦怕是错摸心理

总有天会等到好天气

游行示爱大叫着你在某大遍草地

等你无用退避不过仍然害羞的你

还是顾忌太不争气

明知做戏

即使你未太在意不感到惊讶

现在要说爱你请准备招架

勇气还存在吗

不要害怕

随时真的胆敢亲手送花

离谱吗

请你不要阻我喜欢你

明明是爱但你未说话你扮作闪避

这个沉默冷静的你亳无办法处理

其实我亦怕是错摸心理

总有天会等到好天气

游行示爱大叫着你在某大遍草地

等你无用退避不过仍然害羞的你

还是顾忌太不争气

明知做戏

不过不要阻我紧张你

如何令你愉快让我办妥为你准备

喜爱沉默冷静的你还是自信的你

仍愿意为你造一些惊喜

总有天会等到好天气

游行示爱大叫着你在某大遍草地

等你无用退避不过途人目光不理

期待贴着你的手臂

无须做戏

等你喜爱等你不爱就凭摘毫验证

想爱不爱偏爱不理亦同样难划清

天天如常

估你心情

不想扑索来求证

争取过趁还年青

终于你下决定来答应

太动听