vue3学习四 watch

news2025/1/10 11:48:56

在vue3中使用watch 来监听某个数据的变化, 因为我们定义数据的时候有 ref 和 reactive 两种方法, 所以watch 也会分出不同的五种情况

当使用 watch 来监听 ref 定义的数据时

<template>
  <div> sum: {{sum}}</div>
  <button @click="sum++">sum变化</button>
  <div> msg: {{msg}}</div>
  <button @click="msg+='!'">msg 变化</button>
</template>

<script>
import {ref,reactive,watch} from "vue";
export default {
  name: 'App',
  setup(){
    let sum = ref(0);
    let msg = ref("你好啊");
    // watch(sum,(newvalue,oldvalue)=>{
    //   console.log("sum发生了变化",newvalue,oldvalue);
    // })
    //两个变量一起监听
    watch([sum,msg],(newvalue,oldvalue)=>{
      console.log(newvalue); //此时的 newvalue 是一个数组
      console.log(oldvalue); //此时的 oldvalue 是一个数组
    })
    return {
      sum,
      msg
    }
  },
}
</script>

从上面的代码中, 我们可以看到, 如果我们只监听一个数据的时候可以使用

watch(sum,(newvalue,oldvalue)=>{
	//逻辑代码
},{immediate:true})

如果我们要监听两个或多个数据, 最简单的方法就是 多写一个 watch 就可以了
还可以使用 数组的方式

    watch([sum,msg],(newvalue,oldvalue)=>{
      console.log(newvalue); //此时的 newvalue 是一个数组
      console.log(oldvalue); //此时的 oldvalue 是一个数组
    },{immediate:true})

当我们使用 watch 去监听一个 reactive定义的数据

<template>
  <div>person:{{person}}</div>
  <button @click="person.name+='!'">person name改变</button>
  <br/>
  <button @click="person.age+=1">person age改变</button>
  <br/>
  <button @click="person.job.j1.salary++">person job j1 salary 改变</button>
  <br/>
  <button @click="person.job.j2.salary++">person job j2 salary 改变</button>
</template>

<script>
import {ref,reactive,watch} from "vue";
export default {
  name: 'App',
  setup(){
    let person = reactive({
      name:"黄哥",
      age:38,
      job:{
        j1:{
          salary:20
        },
        j2:{
          salary:50
        }
      }
    })

    watch(person,(newvalue,oldvalue)=>{
      console.log("发现了person发生了变化",newvalue,oldvalue)
    },{immediate:true,deep:false})

    watch(()=>person.age,(newvalue,oldvalue)=>{
      console.log(newvalue,oldvalue)
    })

    watch([()=>person.name,()=>person.age],(newvalue,oldvalue)=>{
      console.log(newvalue,oldvalue)
    })

    watch(()=>person.job,(newvalue,oldvalue)=>{
      console.log(newvalue,oldvalue);
    },{deep:true})

    watch(()=>person.job.j1.salary,(newvalue,oldvalue)=>{
      console.log(newvalue,oldvalue)
    })


    return {
      person
    }
  },
}
</script>

从上面的代码我们可以分现多种情况

情况一 整体监听 person 对象

watch(person,(newvalue,oldvalue)=>{
      console.log("发现了person发生了变化",newvalue,oldvalue)
    },{immediate:true,deep:false})

这里的 person 强制开启了 deep:true , 上面虽然配置了 deep:false, 但是是没有用的,同时还有一个小bug , 这里只能得到 newvalue, oldvalue 是得不到了, 如果实在需要 oldvalue 的话, 可以对每个属性单独监听

情况二 监听其中的某一个属性

    watch(()=>person.age,(newvalue,oldvalue)=>{
      console.log(newvalue,oldvalue)
    })

watch 的第一个参数有三种形式, 第一种, ref或reactive 定义的数据, 第二种, 可以是一个数组,第三种, 也可以是一个回调函数
所以, 这里如果 写成 watch(person.age,…) 这种写法是错误的
正确的写法是 watch(()=>return person.age,…) 简化的写法就是 watch(()=> person.age)

情况三,监听多个属性,这里要使用 回调函数加数组的方式了

    watch([()=>person.name,()=>person.age],(newvalue,oldvalue)=>{
     console.log(newvalue,oldvalue)
   })

其原因和情况二差不多, 不用多说了

情况四 如果监听 person , 是默认强制开启的 {deep:true},配不配deep都是一样的;但如果监听的是 person 内部的对象数据的时候, 是可以使用 deep 来配置的

    watch(()=>person.job,(newvalue,oldvalue)=>{
      console.log(newvalue,oldvalue);
    },{deep:true})

在这里插入图片描述
上面的代码中, 我们更改的是 person.job.j1.salary 发生改变, 但是这里监听的是 person.job, 所以如果我们不配置 deep:true, 则是不可以监听到数据变化的

情况五

    watch(()=>person.job.j1.salary,(newvalue,oldvalue)=>{
      console.log(newvalue,oldvalue)
    })

这种和情况二是差不多的。只不过是更深层的数据

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/505999.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

java非静态代码块和静态代码块介绍

代码块 SE.10.0…02.28 非静态普通代码块&#xff1a;定义在方法内部的代码块&#xff0c;不用任何关键字修饰&#xff0c;又名构造代码块、实例代码块 静态代码块&#xff1a;用static修饰的代码块 非静态代码块 public class Test {public static void main(String[] args…

【EKF】卡尔曼滤波的一维应用实例

前言 推导了卡尔曼滤波的原理之后&#xff0c;使用一个简单的一维应用实例来训练一下&#xff0c;加深印象。使用一个温度测量的实例来说明&#xff0c;系统的状态方程为&#xff1a; X(k) A*X(k-1) B*u(k-1) w(k-1) Z(k) H*X(k) v(k) 其中 w 为过程噪声&#xff0c;方…

方言翻译APP小程序开发具备哪些功能?

我国语言文华博大精深&#xff0c;很多地方都有着民族特色方言&#xff0c;在当地很盛行但是外地人听不懂也不会说&#xff0c;这就給沟通造成了一定的困扰。方言翻译APP软件是专门针对地方性方言开发的一款系统软件&#xff0c;提供全国各地方言翻译功能&#xff0c;一键在线就…

Android中如何使用GPS

目录 GPS简介 GPS的常用API locationProvider 使用GPS获取位置信息 室内WIFI定位 近距离警报 GPS简介 Gobal Positioning System&#xff0c;全球定位系统&#xff0c;是美国在20世纪70年代研制的一种以人造地球卫星为基础的高精度无线电导航的定位系统&#xff0c;它在全…

【手机摄影】--全集

算了&#xff0c;摄像机太贵了&#xff0c;玩不起&#xff0c;还是看看手机摄影吧。 学习链接 &#xff1a;https://www.bilibili.com/video/BV14e411T7md 1. 认识手机摄影 1.1 局限性 手机的摄像头能够满足大部分场景&#xff0c;但以下场景会受到掣肘&#xff0c;最好还是用…

面试这么简单,阿里原来这么容易就能进去…...

最近和阿里的一个老朋友闲聊&#xff0c;感触颇深&#xff0c;据他说公司近期招聘的测试工程师&#xff0c;大多数候选人都有一个“通病”&#xff1a;在工作2-3年的时候遇到瓶颈&#xff0c;而且是一道很难跨越的坎。 为什么会遇到这种情况&#xff1f;因为大部分测试工程师在…

项目管理基础(第五版)读书笔记

项目管理基础&#xff08;第五版&#xff09;读书笔记 章节概要前言第一章&#xff1a;项目管理概述 日期&#xff1a;2023年3月23日 章节概要 前言 项目管理协会 Project Management Institute。简称PMI。项目管理知识体系指南 Project Management Body Of Knowledge。简称P…

4.QT应用程序主窗口

本章代码见文末链接 主窗口框架 新建Qt Wisgets项目mymainwindow&#xff0c;类名默认MainWindow&#xff0c;基类默认QMainWindow 更改文字如图&#xff0c;如果中文无法直接输入&#xff0c;可以试试复制粘贴 “动作编辑器”中&#xff08;默认在右下角&#xff09;&…

关于IRIG-B码对时的理解和分析

一、IRIG-B是什么&#xff1f; IRIG-B&#xff08;简称B码&#xff09;是一种应用于靶场的串行时间交换码。由美国靶场司令部委员会下属“靶场仪器组”提出的一种时间信息编码标准&#xff08;IRIG是英文InterRange Instrumentation Group的缩写。它是美国靶场司令委员会的下属…

一百零八、Kettle采集Kafka数据到HDFS(踩坑,亲测有效)

Kafka到HDFS&#xff0c;除了用Kafka API和flume之外&#xff0c;还可以用kettle&#xff0c;最大优点是不用写代码&#xff01; 版本&#xff1a;Kettle版本&#xff1a;8.2、Hadoop版本&#xff1a;3.1.3 前提&#xff1a; 详情请看鄙人的一百零一、Kettle8.2.0连接Hive…

pip安装配置清华镜像源scrapy框架,并进行框架的案例演示

文章目录 运行cmd终端后直接输入安装成功scrapy框架安装成功 为什么使用此命令安装scrapy框架成功后创建scrapy项目建议在pycharm终端创建项目打开项目 用scrapy框架实现案例——从新浪网爬取热点并把数据输入到excel表中编辑setting.py文件创建脚本、写入脚本在终端运行脚本文…

长三角生物医药产业加速跑,飞桨螺旋桨为创新药企、医药技术伙伴装上AI大模型引擎...

生物医药是国家“十四五”规划中明确的战略性新兴产业之一。长三角地区是中国生物医药产业的排头兵&#xff0c;也是《“十四五”生物经济发展规划》的“生物经济先导区”之一。据《上海市生物医药产业投资指南》显示&#xff0c;2022 年上海市生物医药产业在 I 类国产创新药数…

新手如何学习挖漏洞?【网络安全】

新手如何学习挖漏洞&#xff1f;看这篇就够了 前言 有不少阅读过我文章的伙伴都知道&#xff0c;我从事网络安全行业已经好几年&#xff0c;积累了丰富的经验和技能。在这段时间里&#xff0c;我参与了多个实际项目的规划和实施&#xff0c;成功防范了各种网络攻击和漏洞利用&…

Cron表达式X分钟执行一次的设计缺陷。SQL JOIN的设计缺陷。在线Cron表达式网站的缺陷。Spring 定时任务的年问题。

Cron Cron表达式 定时任务计划任务 Chronological英 /ˌkrɒnəˈlɒdʒɪk(ə)l/adj. 按发生时间顺序排列的&#xff1b;&#xff08;年龄&#xff09;按时间计算的1. 月 周设计精妙吗&#xff1f; 学习 0/5 * * * * ? * 秒 分 时 日 月 周 年1. 年一般省略。为&#xf…

Live800:服务经济时代,企业如何满足客户需求?

在互联网与市场经济的催化下&#xff0c;我们正在从产品经济时代过渡到服务经济时代。在产品经济时代&#xff0c;企业关注的核心是质量和成本&#xff1b;而在服务经济时代&#xff0c;如何面向客户&#xff0c;满足客户需求则成为企业建立核心竞争力的关键。 具体来说&#x…

【精选】关于洪涝灾害智慧水利和人工智能大模型的解决方案2023版

本资料来源公开网络&#xff0c;仅供个人学习&#xff0c;请勿商用&#xff0c;如有侵权请联系删除 智慧水利平台 实现“全局一盘棋”的智慧水利综合管理&#xff0c;通过“一图、一库、一平台”结合水利大数据、数字孪生与人工智能&#xff0c;为水利工作提供有力的管理抓手&…

SingleR --细胞注释

文章目录 briefExample使用内置的 references使用其他注释好的数据集作为 reference singleR还提供了注释诊断的方法 brief Example The celldex package provides access to several reference datasets (mostly derived from bulk RNA-seq or microarray data)。 The Human…

《狂飙》原著来了,邀你重新见证

2023年的开篇十分精彩且丰富&#xff0c;经历过生活的不幸&#xff0c;新的一年万物复兴&#xff0c;每个人心底那颗躁动的心又重新释放&#xff0c;希望新的开始不负所望&#xff0c;年末复盘时所得皆所愿&#xff01; 开篇 开年影视第一炮&#xff0c;炸出了所有人被压抑的内…

AIGC技术发展和应用方向

AIGC&#xff08;Artificial Intelligence Generated Content&#xff09;是指通过人工智能技术生成的各种文本、图像、音频和视频等多媒体内容。AIGC技术是机器学习和自然语言处理等技术的结合&#xff0c;通过对海量数据的学习和分析&#xff0c;可以让计算机模拟人类的创造力…

Spring Boot 单体应用一键升级成 Spring Cloud Alibaba

作者&#xff1a;十眠 背景 随着 Apache Dubbo、Nacos 以及 Spring Cloud 等服务框架的流行&#xff0c;越来越多的企业开始采用微服务架构来构建其应用程序。微服务架构使企业能够将其应用程序拆分成多个小型服务&#xff0c;这些服务可以独立部署和扩展。这种架构模式也使企…