uni-app学习笔记十一--vu3 watch和watchEffect侦听

一. watch

在有些情况下,我们需要在状态变化时执行一些操作,此时可以使用watch来实现这种效果,我们可以使用 watch 函数在每次响应式状态发生变化时触发回调函数。watch 的第一个参数可以是不同形式的"数据源":它可以是一个 ref (包括计算属性)、一个响应式对象、一个 getter 函数、或多个数据源组成的数组,但是注意:watch 直接侦听响应式对象的属性值。下面我们来看下它的用法

用法1:

javascript 复制代码
<script setup>
	import {ref, watch} from "vue"
	const person = ref({
		name:"Jim",
		age:21
	})
	 watch(person,(oldValue,newValue)=>{
	   console.log("oldValue:"+oldValue)
	   console.log("newValue:"+newValue)
	 })
</script>

用法2(推荐使用):

javascript 复制代码
watch(()=>person.value.name,(newValue)=>{
 	console.log("newValue:"+newValue)
})

用法3(比较耗性能,必要时才使用):开启尝试侦听,立即侦听

javascript 复制代码
watch(person,(newValue)=>{
	console.log(newValue)
},{deep:true,immediate:true})

完整代码:

html 复制代码
<template>
	<view>
		<input type="text" v-model="person.name" />
	</view>
	{{person}}
</template>

<script setup>
	import {ref, watch} from "vue"
	const person = ref({
		name:"Jim",
		age:21
	})
	// watch(person,(oldValue,newValue)=>{
	// 	console.log("oldValue:"+oldValue)
	// 	console.log("newValue:"+newValue)
	// })
	
	// watch(()=>person.value.name,(newValue)=>{
	// 	console.log("newValue:"+newValue)
	// })
	
	watch(person,(newValue)=>{
		console.log(newValue)
	},{deep:true,immediate:true})
</script>

<style lang="scss" scoped>
	       
</style>

需要侦听多个,推荐分开侦听:

javascript 复制代码
//nv new value的缩写 新值  ov老值
watch(firstName,(nv,ov)=>{
 
}

watch(lastName,(nv,ov)=>{
 
})

二.watchEffect

watchEffect() 允许我们自动跟踪回调的响应式依赖,性能消耗较大,一般很少使用。

javascript 复制代码
watchEffect(()=>{
		console.log(firstName.value,lastName.value)
	})

三.watch vs. watchEffect

watchwatchEffect 都能响应式地执行侦听。它们之间的主要区别是追踪响应式依赖的方式:

  • watch 只追踪明确侦听的数据源。它不会追踪任何在回调中访问到的东西。另外,仅在数据源确实改变时才会触发回调。watch 会避免在发生副作用时追踪依赖,因此,我们能更加精确地控制回调函数的触发时机。

  • watchEffect,则会在副作用发生期间追踪依赖。它会在同步执行过程中,自动追踪所有能访问到的响应式属性。这更方便,而且代码往往更简洁,但有时其响应性依赖关系会不那么明确。

相关推荐
小时前端3 小时前
微信小程序选不了本地文件?用 web-view + H5 一招搞定
前端·微信小程序·uni-app
Mr_li20 小时前
给 Vue 开发者的 uni-app 快速指南
vue.js·uni-app
anyup1 天前
🔥2026最推荐的跨平台方案:H5/小程序/App/鸿蒙,一套代码搞定
前端·uni-app·harmonyos
Mintopia2 天前
Vue3 项目如何迁移到 uni-app x:从纯 Web 到多端应用的系统指南
uni-app
Mintopia2 天前
uni-app x 发展前景技术分析:跨端统一的新阶段?
uni-app
不爱说话郭德纲3 天前
告别漫长的HbuilderX云打包排队!uni-app x 安卓本地打包保姆级教程(附白屏、包体积过大排坑指南)
android·前端·uni-app
HashTang4 天前
【AI 编程实战】第 12 篇:从 0 到 1 的回顾 - 项目总结与 AI 协作心得
前端·uni-app·ai编程
JunjunZ4 天前
uniapp 文件预览:从文件流到多格式预览的完整实现
前端·uni-app
郑州光合科技余经理5 天前
代码展示:PHP搭建海外版外卖系统源码解析
java·开发语言·前端·后端·系统架构·uni-app·php
西岸行者5 天前
学习笔记:SKILLS 能帮助更好的vibe coding
笔记·学习