【vue】watch 侦听器

发布于:2024-04-14 ⋅ 阅读:(163) ⋅ 点赞:(0)

watch:可监听值的变化,旧值和新值

在这里插入图片描述

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <div id="app">
        爱好
        <select v-model="hobby">
            <option value="">请选择</option>
            <option value="reading">阅读</option>
            <option value="swimming">游泳</option>
            <option value="running">跑步</option>
        </select>
        <hr><select v-model="date.year">
            <option value="">请选择</option>
            <option value="2021">2021</option>
            <option value="2022">2022</option>
            <option value="2023">2023</option>
            <option value="2024">2024</option>
        </select><select v-model="date.month">
            <option value="">请选择</option>
            <option value="1">1</option>
            <option value="2">2</option>
            <option value="3">3</option>
            <option value="4">4</option>
            <option value="5">5</option>
            <option value="6">6</option>
            <option value="7">7</option>
            <option value="8">8</option>
            <option value="9">9</option>
            <option value="10">10</option>
            <option value="11">11</option>
            <option value="12">12</option>
        </select>

    </div>

    <script type="module">
        import { createApp, reactive, ref, watch } from './vue.esm-browser.js'
        createApp({
            setup() {
                const hobby = ref("")
                const date = reactive({
                    year: "",
                    month: ""
                })
                //监听hobby变化
                watch(hobby, (newVal, oldVal) => {
                    console.log("oldVal :", oldVal, "newVal :", newVal)
                })

                //监听某个值,如date.year
                watch(() => date.year, (newVal, oldVal) => {
                    console.log("oldVal :", oldVal, "newVal :", newVal)
                })

                //监听date变化
                //发现date变化时,新旧值一样
                //因为数组和对象通过引用传递,而不是创建一个新的对象或数组
                //newVal, oldVal是指向同一个对象,所以变化时,oldVal, newVal是一样的
                watch(date, (newVal, oldVal) => {
                    console.log("oldVal :", oldVal, "newVal :", newVal)
                })

                return {
                    date,
                    hobby
                }
            }
        }).mount("#app")
    </script>
</body>

</html>

参考

https://www.bilibili.com/video/BV1nV411Q7RX


网站公告

今日签到

点亮在社区的每一天
去签到