Vue的监听器Wacth

Vue的监听器Wacth

watch用于侦听data的数据。
当data数据发生变化时,执行函数。这个函数会传入两个参数,分别是newVal和oldVal。
watch属性可以是字符串、函数、对象、数组
拥有deep(对象深度监听),immediate(vue初始化完毕立即出发。默认是不会,)两属性

Vue的实例Demo

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Vue的监听器Wacth</title>
</head>
<body>

    <div id="app">
        <h1>{{title}}</h1>
    </div>

    <script src="js/vue.global.js"></script>

    <script>
        var vm = Vue.createApp({
            data(){
                return {
                    title:"你好,Vue3"
                }
            }
        }).mount("#app");
    </script>

</body>
</html>

watch用于侦听data的数据。

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-aP2OP5pu-1638799849705)(asserts/image-20211128202439350.png)]

当data数据发生变化时,执行函数。这个函数会传入两个参数,分别是newVal和oldVal。

  • newVal:改变以后的值
  • oldVal:改变之前的值
 var vm = Vue.createApp({
        data() {
            return {
                title: "你好,Vue3"
            }
        },
        watch: {
            title(newVal, oldVal) {
                console.log("newVal", newVal, "oldVal:", oldVal)
            }
        }
    }).mount("#app");

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-AS4Ll82C-1638799849708)(asserts/image-20211128202650534.png)]

deep

deep:深度的含义。

为什么会有deep这种东西存在

  • 在vue的data数据结构中,不仅仅只有字符串,数字,日期等,还有:对象,数组。函数等

  • 默认情况下:vue并没有对对象改变数据的监听进行处理。只对自身覆盖会进行监听

  • [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-TIQWFq4q-1638799849709)(asserts/image-20211128203943254.png)]

  • 但是,直接对象改变属性并不会监听。因为vue默认是关闭改变属性的监听。为什么呢?考虑到性能的问题。因为对象改变属性是非常频繁的操作。而且深度是不可控,如果你要去监听。自己手动开启这对象的深度监听:deep:true

deep如果编写和监听呢?

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Vue的监听器Wacth</title>
</head>
<body>

<div id="app">
    <h1>{{title}}</h1>
    <h1>{{user.id}}==={{user.username}}==={{user.age}}</h1>
    <h3>{{user.person.pid}}</h3>
</div>

<script src="js/vue.global.js"></script>

<script>
    var vm = Vue.createApp({
        data() {
            return {
                title: "Hello",
                user: {
                    id: 1,
                    person: {pid: 1},
                    username: "yykk",
                    age: 35
                }
            }
        },
        watch: {
            title: function (newv, oldv) {
                console.log("newv:", newv)
                console.log("oldv:", oldv)
            },
            user: {
                handler: function (newVal, oldVal) {
                    console.log("newVal:", newVal)
                    console.log("oldVal:", oldVal)
                },
                deep: true
            },

        }
    }).mount("#app");
</script>

</body>
</html>

从测试得出结论:不论对象层级多深都会监听。比如:vm.user.id、vm.user.person.pid =100,如下:

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-km0pPXLu-1638799849709)(asserts/image-20211128204450369.png)]

immediate

  • immediate= false (默认值) 请注意:watch默认情况下,不会立即去加载监听的对象的处理函数。它一定要改变data的值才会触发。
  • immediate=true,只要vue一加载完毕马上就要触发一次。(默认一定加载一次)。
<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Vue的监听器Wacth</title>
</head>
<body>

<div id="app">
    <h1>{{title}}</h1>
    <h1>{{user.id}}==={{user.username}}==={{user.age}}</h1>
    <h3>{{user.person.pid}}</h3>
</div>

<script src="js/vue.global.js"></script>

<script>
    var vm = Vue.createApp({
        data() {
            return {
                title: "Hello",
                user: {
                    id: 1,
                    person: {pid: 1},
                    username: "yykk",
                    age: 35
                }
            }
        },
        created(){
          console.log(111111111111111)
        },
        watch: {
            title: function (newv, oldv) {
                console.log("newv:", newv)
                console.log("oldv:", oldv)
            },
            user: {
                handler: function (newVal, oldVal) {
                    console.log("newVal:", newVal)
                    console.log("oldVal:", oldVal)
                },
                deep: true,
                immediate:false // 默认不会立即加载一定改变才会触发和执行 ,如果你想立即加载,请修改为true
            },

        }
    }).mount("#app");
</script>

</body>
</html>

watch有什么用处呢?

查看视频,登录案例

 deep: true,
            immediate:false // 默认不会立即加载一定改变才会触发和执行 ,如果你想立即加载,请修改为true
        },

    }
}).mount("#app");
```
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值