Vue3的watch侦听器以及与Vue2的watch的侦听器区别

一、Vue3的watch侦听器:

1、基础用法侦听单个数据

  1. 导入watch函数
  2. 执行watch函数传入要侦听的响应式数据(ref对象)和回调函数
javascript 复制代码
<template>
  <button @click="add">
    {{ count }}
  </button>
<template>

<script>
    //导入watch
    import { ref, watch } from 'vue'
    const count = ref(0)
    const add = () => count.value++
    //调用watch侦听变化
    //count:ref参数不需要加.value
    watch(count,(newVla,oldVal) => {
    console.log('旧值为',oldVal,'新值为',newVal)
})
<script>

2、侦听多个数据

javascript 复制代码
<script setup>
  // 1. 导入watch
  import { ref, watch } from 'vue'
  const count = ref(0)
  const name = ref('cp')
  // 2. 调用watch 侦听变化
  watch([count, name], ([newCount, newName],[oldCount,oldName])=>{
    console.log(`count或者name变化了,[newCount, newName],[oldCount,oldName])
  })
</script>

3、立即监听 (immediate)

在侦听器创建时立即发出回调,响应式数据变化之后继续执行回调

javascript 复制代码
<script setup>
  // 1. 导入watch
  import { ref, watch } from 'vue'
  const count = ref(0)
  // 2. 调用watch 侦听变化
  watch(count, (newValue, oldValue)=>{
    console.log(`count发生了变化,老值为${oldValue},新值为${newValue}`)
  },{
    immediate: true
  }) 
</script>

4、深度监听

通过watch监听的ref对象默认是浅层侦听的,直接修改嵌套的对象属性 不会 触发回调执行,需要开启deep

javascript 复制代码
<script setup>
  // 1. 导入watch
  import { ref, watch } from 'vue'
  // 这里有两个属性
  const state = ref({ count: 0, age: 18 })
  // 2. 监听对象state 并开启deep
  watch(state, ()=>{
    console.log('数据变化了')
  },{deep:true})
  const changeStateByCount = ()=>{
    // 此时修改可以触发回调
    state.value.count++
  }
</script>

5、精确监听

开启deep的问题: 它会递归地处理处理所有的值,无论哪个属性被修改都会触发watch回调,这可能会导致不必要的浪费。

javascript 复制代码
  watch(()=>state.value.name, (newVal, oldVal) => {
    console.log('name变化了')
  })

二、区别

1、首先他们都可以监听数据对象和计算属性的变化,Vue3的还可以监听ref和reactive的变化。

2、vue2可以监听单个属性或深度监听整个对象,vue3默认只监听单个属性的变化,不在支持深度监听,如果需要深度监听需要使用deep来实现。

3、vue3中的回调函数可以接受到变化的新值和旧值作为参数,方便进行比较处理。

相关推荐
怪兽毕设3 分钟前
基于SpringBoot的选课调查系统
java·vue.js·spring boot·后端·node.js·选课调查系统
DFT计算杂谈6 分钟前
VASP+PHONOPY+pypolymlpj计算不同温度下声子谱,附批处理脚本
java·前端·数据库·人工智能·python
广州华水科技9 分钟前
如何选择合适的单北斗变形监测系统来保障水库安全?
前端
Mr_Xuhhh14 分钟前
MySQL表的内连接与外连接详解
java·前端·数据库
Amumu1213815 分钟前
Vue Router(一)
前端·javascript·vue.js
2603_9494621017 分钟前
Flutter for OpenHarmony 社团管理App实战 - 资产管理实现
开发语言·javascript·flutter
郑州光合科技余经理17 分钟前
可独立部署的Java同城O2O系统架构:技术落地
java·开发语言·前端·后端·小程序·系统架构·uni-app
清山博客18 分钟前
jQuery easyui 扩展datetimebox控件,增加上午、中午、下午快速选择
前端·jquery·easyui
VT.馒头32 分钟前
【力扣】2694. 事件发射器
前端·javascript·算法·leetcode·职场和发展·typescript