vue3--组合式API-watch

侦听单个数据 / 多个数据 /立即回调

<script setup>
import { ref ,watch} from "vue";
const count = ref(0)
const nickname = ref('张三')


const changeCount=()=>{
  count.value++
}
const changeNickName =()=>{
  nickname.value = '李四'
}


// 1. 监视单个数据 :  watch(ref对象,(newValue,oldValue)=>{.....})
 watch(count,(newValue,oldValue)=>{
   console.log(newValue,oldValue)//1 0
})
// 2. 监视多个数据: watch(【ref对象,ref对象)】,(newValue,oldValue)=>{....}
watch([count,nickname],(newArr,oldArr)=>{
   console.log(newArr,oldArr)
// 3.immediate--在创建侦听器时立即触发回调
 watch(count,(newValue,oldValue)=>{
   console.log(newValue,oldValue)
 },{
   immediate:true,
 }
 )


</script>
<template>
  <div>{{ count }}</div>
  <button @click="changeCount">改数字</button>
  <div>{{ nickname }}</div>
  <button @click="changeNickName">改昵称</button>

  
</template>

 深度侦听deep

<script setup>
import { ref ,watch} from "vue";


// 4.deep深度监视--由于默认watch是浅层监视,
// const数据ref= ref(简单类型),可以直接监视 
// but  如果const2 数据ref = ref(复杂类型),监视不到

 const userInfo = ref({
   name:'zs',
   age:18
 })
 const  setUserInfo=()=>{
   userInfo.value.age++
  userInfo.value.name='ls'
}
 watch(userInfo,(newValue)=>{
  console.log(newValue);//没有deep:true监视不到,修改整个userInfo整个对象才能监视

 },{
   deep:true
 })

</script>

<template>
 
  <div>{{ userInfo }}</div>
  <button @click="setUserInfo">修改userinfo</button>
</template>

精确侦听对象的某一个属性

<script setup>
import { ref ,watch} from "vue";

//5.精确侦听对象的某一个属性
 const userInfo = ref({
  name:'zs',
  age:18
})
const  setUserInfo=()=>{
  userInfo.value.age++
  userInfo.value.name='ls'
}
watch(
  ()=> userInfo.value.name,
  ()=>console.log('发生了变化')
)


</script>
<template>
 
  <div>{{ userInfo }}</div>
  <button @click="setUserInfo">修改userinfo</button>
</template>

Vue 3组合式 API (Composition API) 提供了一种更直观的方式来组织和复用逻辑,`watch` 就是其中一个重要的响应式工具。它允许开发者监听响应式数据的变化,并在变化发生时触发回调函数。 ### 使用 `watch` 假设我们有一个简单的 Vue 应用程序,在其中我们要监视一个状态变量并作出反应: ```javascript import { ref, watch } from &#39;vue&#39;; export default { setup() { // 定义了一个ref类型的响应式属性 const count = ref(0); // 监听count值的变化 watch(count, (newVal, oldVal) => { console.log(`新的计数值: ${newVal}, 老的计数值: ${oldVal}`); }); return { count, }; }, }; ``` 在这个例子中,当 `count` 发生改变的时候就会打印新旧两个值到控制台。 如果需要同时观察多个源,则可以传递一个数组作为第一个参数给 `watch` 函数: ```javascript // 同时监控多个ref或者其他reactive对象里的属性 const stateA = reactive({ a: 1 }); const b = ref(&#39;hello&#39;); watch([() => stateA.a, b], ([newA, newB], [prevA, prevB]) => { console.log(`a changed from ${prevA} to ${newA}.`); console.log(`b changed from ${prevB} to ${newB}.`); }); ``` 此外还有其他一些有用的选项如立即执行、深度侦测等: ```js watch(source, callback, { immediate: true, // 立即执行一次回调 deep: true // 深度比较,用于复杂的数据结构比如对象或者数组内部元素发生变化的情况 }) ``` 通过合理的运用 `watch`, 可以简化代码并且提高性能,使得组件之间的依赖关系更为清晰明了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值