vue3 数据监听(watch、watchEffect)

1、watch

1.1基本使用

作用:数据监听

语法:

watch(监听的数据, (改变后的数据, 改变前的数据) => {

console.log(newVal, oldVal);

})

注意点:watch写法上支持一个或者多个监听源,这些监听源必须只能是getter/effect函数,ref数据,reactive对象,或者是数组类型

javascript 复制代码
<template>
  <div>
    <h1>watch</h1>
    <p>name: {{ name }} <button @click="btn">修改名字</button></p>
    <p><input type="text" v-model="code" /> {{ code }}</p>
  </div>
</template>

<script setup>
import { ref,reactive,toRefs, watch } from 'vue';
  // 定义变量
  let name=ref('张三')
  const btn=()=>{
    name.value='李四'
  }
  // 监听单个数据
  watch(name,(newVal,oldVal)=>{
    //            李四 张三
    console.log(newVal,oldVal);
  })
  // 定义对象
  let res=reactive({
    code:200,
    data:[],
    massge:'ok'
  })
  const {code}=toRefs(res)
  // 监听对象
  watch(()=>res.code,(newVal,oldVal)=>{
    //            2001 200
    console.log(newVal,oldVal);
  })

  // 监听多个数据
  watch([name,()=>res.code],(newVal,oldVal)=>{
    //['张三', '2001'] ['张三', 200]
    console.log(newVal,oldVal);
  })
</script>

1.2、深度监听、立即监听

关键字:

deep:true 深度监听

immediate:true 立即监听

javascript 复制代码
<template>
  <div>
    <h1>watch</h1>
    <p><input type="text" v-model="res.user.name" /> {{ res.user.name }}</p>
  </div>
</template>

<script setup>
import { ref,reactive,toRefs, watch } from 'vue';
  // 定义对象
  let res=reactive({
    user:{
    	name:'张三'
    }
  })
  // 监听多个数据
  watch(()=>res.user,(newVal,oldVal)=>{
    console.log(newVal,oldVal);
  },
  {deep:true,immediate:true})
</script>

2、watchEffect

watchEffect用来简化 watch,不需要指定监听对象

而是根据函数内的依赖,用到了什么 当它发生变化时,自动触发

watchEffect回调会立即执行 不需要指定immediate

javascript 复制代码
    <template>
        <div>
          <h1>watchEffect</h1>
          <p><input type="text" v-model.number="num1">
              <input type="text" v-model.number="num2">
          </p>
        </div>
      </template>

      <script setup>
      import { ref,watchEffect } from 'vue';
        let num1=ref(0);
        let num2=ref(1);

        watchEffect(()=>{
            console.log(num1.value+num2.value);
            console.log('执行啦watchEffect');
        })
      </script>
对比点 watch watchEffect
惰性 有惰性,不设置就不会立即执行 没有惰性,会立即执行
参数 语法上多个参数 不需要传递参数
获取值 可以获取到新旧值 不能获取到新旧值
相关推荐
一 乐8 分钟前
校园二手交易|基于springboot + vue校园二手交易系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端
科技D人生19 分钟前
Vue.js 学习总结(20)—— Vue-Office 实战:word、pdf、excel、ppt 多种文档的在线预览
vue.js·word·vue-pdf·stylesheet·docx-preview·vue-office
vx1_Biye_Design20 分钟前
基于Spring Boot+Vue的学生管理系统设计与实现-计算机毕业设计源码46223
java·vue.js·spring boot·spring·eclipse·tomcat·maven
vx_Biye_Design21 分钟前
基于Spring Boot+vue的湖北旅游景点门票预约平台的设计--毕设附源码29593
java·vue.js·spring boot·spring cloud·servlet·eclipse·课程设计
hedley(●'◡'●)22 分钟前
基于cesium和vue的大疆司空模仿程序
前端·javascript·vue.js·python·typescript·无人机
qq5_81151751523 分钟前
web城乡居民基本医疗信息管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
百思可瑞教育24 分钟前
构建自己的Vue UI组件库:从设计到发布
前端·javascript·vue.js·ui·百思可瑞教育·北京百思教育
百锦再24 分钟前
Vue高阶知识:利用 defineModel 特性开发搜索组件组合
前端·vue.js·学习·flutter·typescript·前端框架
hdsoft_huge26 分钟前
1panel面板中部署SpringBoot和Vue前后端分离系统 【图文教程】
vue.js·spring boot·后端
CappuccinoRose1 小时前
JavaScript 学习文档(二)
前端·javascript·学习·数据类型·运算符·箭头函数·变量声明