vue3学习记录-watch

vue3学习记录-watch

  • 1.watch
  • 2.watchEffect

1.watch

直接总结下。。。

<script setup>
import { ref, reactive, computed, watch } from 'vue'const input = ref('小邱')
const input1 = ref('小小邱')
const input3 = ref('3')
const input4 = ref('4')
const x = ref('1')
const y = ref('2')
const obj = reactive({a: {b: {c: 1}}
})
const obj2 = reactive({a: {b: {c: 1}}
})
const obj3 = reactive({a: {b: {c: 1}}
})
//单个监听
watch(input, (newval, oldval) => {console.log(newval, oldval)
})
watch(input1, (newval, oldval) => {console.log(newval, oldval)
})//深度监听
//深度监听对象 监听前后的值都是新值
watch(obj3, (newval, oldval) => {console.log('深层监听', newval, oldval)
})
//不能直接侦听响应式对象的属性值 !
watch(obj.a.b.c, (newval, oldval) => {console.log('深层监听obj.a.b.c', newval, oldval)
})
watch(() => obj.a.b.c, (newval, oldval) => {console.log('深层监听obj.a.b.c', newval, oldval)
})//一次监听多个
watch([input3, input4], (newval, oldval) => {console.log(newval, oldval)
})
watch([input3, () => input4.value], (newval, oldval) => {console.log('多个input监听箭头函数写法', newval, oldval)
})
watch([input3,() => obj2.a.b.c], (newval, oldval) => {console.log('多个input监听带深层属性', newval, oldval)
})
//多个input监听带深层对象 监听前后的值都是新值
watch([input3,obj2], (newval, oldval) => {console.log('多个input监听带深层对象', newval, oldval)
})// getter 函数
watch(() => x.value + y.value,(sum, oldsum) => {console.log(`sum of x + y is: ${sum},oldsum:${oldsum}`)}
)
//这样写算是错误写法 监听不到 因为x+y不是一个响应式对象
watch(() => x + y,(sum, oldsum) => {console.log(`sum111 of x + y is: ${sum},oldsum:${oldsum}`)}
)
</script><template><div class="app"><div class="content"><p>单个监听</p><el-input v-model="input"></el-input><el-input v-model="input1"></el-input><p>深度监听</p><el-input v-model="obj3.a.b.c"></el-input><el-input v-model="obj.a.b.c"></el-input><p>一次监听多个</p><el-input v-model="input3"></el-input><el-input v-model="input4"></el-input><el-input v-model="obj2.a.b.c"></el-input><p>getter 函数</p><el-input-number v-model="x"></el-input-number><el-input-number v-model="y"></el-input-number></div></div></template><style scoped>
.app {display: flex;align-items: center;justify-content: center;
}
</style>

2.watchEffect

侦听器的回调使用与源完全相同的响应式状态是很常见的。例如下面的代码,在每当 todoId 的引用发生变化时使用侦听器来加载一个远程资源:

const todoId = ref(1)
const data = ref(null)watch(todoId,async () => {const response = await fetch(`https://jsonplaceholder.typicode.com/todos/${todoId.value}`)data.value = await response.json()},{ immediate: true }
)

特别是注意侦听器是如何两次使用 todoId 的,一次是作为源,另一次是在回调中。其实,这样写也是可以的。

watch(todoId,async (newVal) => {const response = await fetch(`https://jsonplaceholder.typicode.com/todos/${newVal}`)data.value = await response.json()},{ immediate: true }
)

我们可以用 watchEffect 函数 来简化上面的代码。watchEffect() 允许我们自动跟踪回调的响应式依赖。上面的侦听器可以重写为:

watchEffect(async () => {const response = await fetch(`https://jsonplaceholder.typicode.com/todos/${todoId.value}`)data.value = await response.json()
})

对于这种只有一个依赖项的例子来说,watchEffect() 的好处相对较小。但是对于有多个依赖项的侦听器来说,使用 watchEffect() 可以消除手动维护依赖列表的负担。

import { ref, watchEffect } from 'vue';setup() {const x = ref(1);const y = ref(2);const z = ref(3);watchEffect(() => {console.log(`x + y + z = ${x.value + y.value + z.value}`);});// 后续对 x, y, z 的任何修改都会触发 watchEffect 中的函数
}

在这个例子中,我们创建了三个响应式引用 x、y 和 z。然后我们使用 watchEffect 来观察它们的和。由于我们没有指定依赖项,watchEffect 会自动追踪 x.value、y.value 和 z.value。无论 x、y 还是 z 发生变化,watchEffect 中的函数都会被重新执行,并打印出新的和。

如果你使用 watch 来实现同样的功能,你需要手动指定依赖项:

import { ref, watch } from 'vue';setup() {const x = ref(1);const y = ref(2);const z = ref(3);watch(() => x.value + y.value + z.value,(newSum) => {console.log(`x + y + z = ${newSum}`);});// 这需要你手动维护依赖项列表,当依赖项增加时,你需要更新 watch 的第一个参数
}

使用 watchEffect 可以简化这个过程,因为你不需要手动维护依赖项列表。当项目中的状态变化比较复杂或者依赖项很多时,watchEffect 可以大大简化代码。
学习ing,后续随缘再更新

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

sass学习笔记(1.0)

1.使用变量 sass可以像声明变量那样进行使用&#xff0c;这样同样的样式&#xff0c;就可以使用相同的变量来提高复用。 语法为&#xff1a;$ 变量名 在界面中也可以正常的显示 当然了&#xff0c;变量之间也可以相互引用&#xff0c;比如下面 div{$_color: #d45387;$BgColo…

Word 拼写检查如何关闭?2 步轻松搞定

在日常进行文档编辑操作的过程中&#xff0c;拼写词语错误是比较常见的&#xff0c;特别是文档中包含大量文字的时候&#xff0c;一不小心就有可能输错&#xff0c;Word 当然有功能可以辅助我们发现这些问题&#xff0c;这就是 Word 拼写检查功能。 Word 拼写检查功能可以自动…

Spring Boot学习资源库:Java开发者的新篇章

2 相关技术简介 2.1Java技术 Java是一种非常常用的编程语言&#xff0c;在全球编程语言排行版上总是前三。在方兴未艾的计算机技术发展历程中&#xff0c;Java的身影无处不在&#xff0c;并且拥有旺盛的生命力。Java的跨平台能力十分强大&#xff0c;只需一次编译&#xff0c;任…

Java基本数据类型转换

一、自动类型转换 1.基本介绍 当Java程序在进行赋值或者运算时&#xff0c;精度小的类型自动转换为精度大的数据类型&#xff0c;这个就是自动类型转换数据类型按精度&#xff08;容量&#xff09;大小进行排序为&#xff1a; ![在这里插入图片描述](https://i-blog.csdnimg.…

【第2章 开始学习C++】C++语句

文章目录 导语声明语句和变量赋值语句cout的新花样使用cin类简介 导语 C 程序是一组函数&#xff0c; 而每个函数又是一组语句。 C 有好几种语句&#xff0c;例如&#xff1a;声明语句创建变量&#xff0c; 赋值语句给该变量提供一个值。 声明语句和变量 计算机是一种精确的…

Java 的数据结构整理(整合版)

Java 的数据结构整理&#xff08;整合版&#xff09; 一、数据输入输出 https://www.runoob.com/java/java-scanner-class.html 这部分是为了预防 leetcode 刷习惯了&#xff0c;忘记怎么处理输入输出的问题 数据输入 Java的数据输入和 C 相比非常繁琐&#xff0c;因此大多…

zookeeper API使用——znode的CRUD

这应该是目录 一、创建连接1.1构造函数1.2创建连接(封装) 二、节点操作2.1创建节点create语法代码 2.2获取节点数据getData语法代码 2.3获取子节点getChildren语法代码 2.4修改节点的值setData语法代码 2.5删除delete语法代码 以下的代码只能作为基础的语法使用&#xff0c;为了…

LangChain: 大语言模型的新篇章

本文介绍了LangChain框架&#xff0c;它能够将大型语言模型与其他计算或知识来源相结合&#xff0c;从而实现功能更加强大的应用。接着&#xff0c;对LangChain的关键概念进行了详细说明&#xff0c;并基于该框架进行了一些案例尝试&#xff0c;旨在帮助读者更轻松地理解LangCh…

65 切面AOP

65 切面AOP 切面基础概念 AOP&#xff1a;Aspect Oriented Programming&#xff0c;面向切面编程。是通过预编译方式&#xff08;aspectj&#xff09;或者运行期动态代理&#xff08;Spring&#xff09;实现程序功能的统一维护的技术。 面试问题&#xff1a; Spring的两大核心…

【VUE】双端比较算法

假设我们有两个虚拟节点 oldVnode 和 newVnode&#xff0c;它们分别对应的DOM结构为&#xff1a; 我们需要将 oldVnode 更新为 newVnode&#xff0c;这时就可以使用双端比较算法了。算法本质上是将新旧节点进行一次交叉比较&#xff0c;尽可能地重复使用已有的节点来达到最小…

懒人笔记-QT程序UOS打包篇

懒人笔记-uos打包篇 前言1、deploy2、组织打包目录2.1 控制文件2.1.1 control的内容&#xff1a;2.1.2 postinst的内容&#xff1a;2.1.3 postrm的内容&#xff1a; 2.2 执行程序2.3 开机自启&#xff08;可选项&#xff09; 3、输出deb安装包4、服务卸载4.1 服务卸载4.2 程序按…

Web自动化Demo-PHP+Selenium

1.新建工程 打开PhpStorm新建工程如下&#xff1a; 打开终端输入如下命令安装selenium&#xff1a; composer require php-webdriver/webdriver 2.编写代码 <?php require vendor/autoload.php;use Facebook\WebDriver\Remote\RemoteWebDriver; use Facebook\WebDriver…

BMS-绝缘检测

一、为什么要进行绝缘检测 前言&#xff1a;BMS绝缘检测是指对电池组与车体之间的绝缘状态进行实时监测和检测。为了确保电池组与车体之间的绝缘性能良好&#xff0c;防止漏电和短路等安全隐患&#xff0c;BMS绝缘检测系统能够及时发现绝缘故障&#xff0c;并采取相应的措施进…

计算机毕业设计Python深度学习游戏推荐系统 Django PySpark游戏可视化 游戏数据分析 游戏爬虫 Scrapy 机器学习 人工智能 大数据毕设

主要功能如下&#xff1a; &#xff08;1&#xff09;用户管理模块&#xff1a;用户能够注册、登录及修改个人信息&#xff0c;查看热门游戏及攻略信息。 &#xff08;2&#xff09;数据采集与处理模块&#xff1a;主要通过Python编程&#xff0c;爬取Tap Tap社区中游戏热门榜…

python发送邮件带附件:配置全指南与步骤?

python发送邮件带附件教程&#xff1f;python如何发邮件带附件&#xff1f; 无论是工作报告、项目文档还是个人通知&#xff0c;邮件都能快速传递信息。而当这些信息需要附带文件时&#xff0c;Python发送邮件带附件的功能就显得尤为重要。AokSend将详细介绍如何使用Python发送…

简易入门:使用Docke 部署一个tomcat服务

简易入门&#xff1a;使用Docke 部署一个tomcat服务 # 拉取 >docker pull tomcat:9.0# 后台运行容器&#xff0c;端口映射为8080. -p 宿主机端口:容器端口 >docker run -d --name tomcat-c-01 -p 8080:8080 tomcat:9.0# 查看容器id >docker ps CONTAINER ID IMAG…

大数据毕业设计选题推荐-王者荣耀战队数据分析-Python数据可视化-Hive-Hadoop-Spark

✨作者主页&#xff1a;IT研究室✨ 个人简介&#xff1a;曾从事计算机专业培训教学&#xff0c;擅长Java、Python、微信小程序、Golang、安卓Android等项目实战。接项目定制开发、代码讲解、答辩教学、文档编写、降重等。 ☑文末获取源码☑ 精彩专栏推荐⬇⬇⬇ Java项目 Python…

图解 微信开发者工具 小程序源码 调试、断点标记方法 , 微信小程序调试器,真机调试断点调试方法,小程序网络API请求调试方法 总结

在我们使用微信开发者工具进行微信小程序开发的时候&#xff0c;在这个微信开发者工具的代码编辑框里面我们是无法像使用vscode, idea等IDE工具时那样直接对代码打断点进行调试&#xff0c; 原因是小程序实际上他就是一个web浏览器应用的包装, 在其内部使用的还是类似chrome的…

Mysql数据库安装与C++配置

本文档旨在为需要安装和配置MySQL 8.3、MySQL Workbench以及C Connector的用户提供详细的步骤指导。在安装过程中&#xff0c;可能会遇到一些常见问题&#xff0c;如DLL文件缺失等&#xff0c;本指南也会提供相应的解决办法。 1.安装Mysql8.3 安装Mysql有很多教程&#xff0c…

10.MySql全局参数优化

从上图可以看出SQL及索引的优化效果是最好的&#xff0c;而且成本最低&#xff0c;所以工作中我们要在这块花更多时间。 一、全局参数 配置文件my.ini(windows)或my.cnf(mac)的全局参数&#xff1a; 假设服务器配置为&#xff1a; CPU&#xff1a;32核 内存&#xff1a;64G…