Vue基础(8)_监视属性、深度监视、监视的简写形式

监视属性(watch):

1.当被监视的属性变化时,回调函数(handler)自动调用,进行相关操作。

2.监视的属性必须存在,才能进行监视!!

3.监视的两种写法:

(1).new Vue时传入watch配置

(2).通过vm.$watch监视

handler

在Vue中,handler方法是用于处理监听属性变化的函数。它通常与watch属性一起使用,用于监控数据的变化并执行相应的操作。handler方法可以帮助我们将处理逻辑抽象出来,以便复用和维护。

可传递参数:
newValue、oldValue(参数名可以自定义),但是第一个是修改后的属性值,第二个是原先的属性值

immediate(布尔值)

immediate:立即的、马上的、立刻执行的。默认为 false。

作用:初始化时让handler先调用一下。

深度监视(deep):

(1).Vue中的watch默认不监测对象内部值的改变。

(2).配置deep:true可以监测对象内部值改变(多层级结构监视)。

备注:

(1).Vue自身可以监测对象内部值的改变,但Vue提供的watch默认不可以!

(2).使用watch时根据数据的具体结构,决定是否采用深度监视。

监视的简写形式

前提条件:不需要immediate和deep属性,只需要handler时可简写。

javascript 复制代码
watch:{
    isHot(){
        ....
    }
}

或者:

javascript 复制代码
vm.$watch("isHot", function(){
    ...
})

举例:

html 复制代码
<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <script type="text/javascript" src="../js/vue.js"></script>
    <title>天气案例</title>
</head>
<body>
    <div id="root">
        <h2>今天天气很{{info}}</h2>
        <!-- 绑定事件的时候:@xxx = "yyy" 中的 yyy 可以写一些简单的语句 -->
        <!-- 下面的语句可简写成: <button @click = isHot = !isHot;>改变天气</button> -->
        <button @click=changeWeacher>改变天气</button>
        <h2>a的值是:{{numbers.a}}</h2>
        <button @click="numbers.a++">点一次加1</button>
    </div>
</body>
<script>
    const vm = new Vue({
        el: "#root",
        data: {
            isHot: true,
            numbers: {
                a: 1,
                b: 1
            }
        },
        computed: {
            info() {
                return this.isHot ? '炎热' : '凉爽';
            }
        },
        methods: {
            changeWeacher() {
                this.isHot = !this.isHot;
            }
        },
        watch: {
            // 监视计算属性的变化(info)
            info: {
                // 初始化时让handler调用一下。immediate:立即的、马上的、立刻执行的。
                immediate: true,
                // handler什么时候调用?当info发生改变时。
                handler(newValue, oldValue) {
                    console.log("info被修改了, 新值为:" + newValue, "旧值:" + oldValue)
                }
            },
            // 监视多级结构中某个属性的变化(numbers.a)
            'numbers.a': {
                handler(newValue, oldValue) {
                    console.log("a的值改变了,新值为:" + newValue, "旧值:" + oldValue)
                }
            },

            // 监视多级结构中所有属性的变化(numbers.a、numbers.b等等)
            'numbers': {
                // 深度监视开启
                deep: true,
                handler() {
                    console.log("numbers对象里有的值改变了")
                }
            }
        }
    })
    // 正常写法
    vm.$watch('isHot', {
        // immediate: true,
        // deep:true,
        handler(newValue, oldValue) {
            console.log("监视isHot变化", "新值为:" + newValue, "旧值:" + oldValue)
        }
    })
    // 简写形式
    vm.$watch('isHot',
        function (newValue, oldValue) {
            console.log("【监视isHot值,代码简写】", "新值为:" + newValue, "旧值:" + oldValue)
        }
    )
    // 以上监视numbers.a的简写形式
    // 'numbers.a'(newValue, oldValue) {
    //     console.log("【监视a值代码简写】新值为:" + newValue, "旧值:" + oldValue)
    // },
</script>
</html>

点击 "改变天气" 后。。。

点击 "点一次加1" 后 。。。

相关推荐
知识分享小能手2 小时前
uni-app 入门学习教程,从入门到精通,uni-app基础扩展 —— 详细知识点与案例(3)
vue.js·学习·ui·微信小程序·小程序·uni-app·编程
demi_meng3 小时前
reactNative 遇到的问题记录
javascript·react native·react.js
MC丶科4 小时前
【SpringBoot 快速上手实战系列】5 分钟用 Spring Boot 搭建一个用户管理系统(含前后端分离)!新手也能一次跑通!
java·vue.js·spring boot·后端
千码君20164 小时前
React Native:从react的解构看编程众多语言中的解构
java·javascript·python·react native·react.js·解包·解构
90后的晨仔6 小时前
Pinia 状态管理原理与实战全解析
前端·vue.js
EndingCoder6 小时前
WebSocket实时通信:Socket.io
服务器·javascript·网络·websocket·网络协议·node.js
90后的晨仔6 小时前
Vue3 状态管理完全指南:从响应式 API 到 Pinia
前端·vue.js
90后的晨仔6 小时前
Vue 内置组件全解析:提升开发效率的五大神器
前端·vue.js
我胡为喜呀6 小时前
Vue3 中的 watch 和 watchEffect:如何优雅地监听数据变化
前端·javascript·vue.js
liangshanbo12159 小时前
React 19 vs React 18全面对比
前端·javascript·react.js