【vue】watchEffect 自动侦听器

watchEffect:自动监听值的变化

  • 获取旧值时,不是很方便,建议用watch
html 复制代码
<!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, watchEffect } from './vue.esm-browser.js'
        createApp({
            setup() {
                const hobby = ref("")
                const date = reactive({
                    year: "",
                    month: ""
                })
                //自动监听
                watchEffect(() => {
                    console.log("----- 自动监听开始")
                    console.log(hobby.value)
                    console.log(date.year, date.month)
                    console.log("自动监听结束 -----")
                })

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

</html>

参考

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

相关推荐
~欲买桂花同载酒~1 小时前
项目优化-vite打包优化
前端·javascript·vue.js
kyriewen1 小时前
JavaScript 继承的七种姿势:从“原型链”到“class”的进化史
前端·javascript·ecmascript 6
wangfpp2 小时前
性能优化,请先停手:为什么我劝你别上来就搞优化?
前端·javascript·面试
踩着两条虫2 小时前
AI 驱动的 Vue3 应用开发平台 深入探究(二十):CLI与工具链之构建配置与Vite集成
前端·vue.js·ai编程
踩着两条虫2 小时前
AI 驱动的 Vue3 应用开发平台 深入探究(二十):CLI与工具链之自定义构建插件
前端·vue.js·ai编程
三旬82 小时前
Day.js 源码深度剖析:极简时间库的设计艺术
javascript
清风徐来QCQ2 小时前
js中的模板字符串
开发语言·前端·javascript
SuperEugene3 小时前
Vue3 + Element Plus 表格实战:批量操作、行内编辑、跨页选中逻辑统一|表单与表格规范篇
开发语言·前端·javascript
极梦网络无忧3 小时前
基于 Vite + Vue3 的组件自动注册功能
前端·javascript·vue.js
软弹4 小时前
深入理解 React Ref 机制:useRef 与 forwardRef 的协作原理
前端·javascript·react.js