Vue 3 中监听多个数据变化的几种方法

1. 使用 watch监听多个 ref/reactive 数据

javascript 复制代码
import { ref, watch } from 'vue'

export default {
  setup() {
    const count = ref(0)
    const name = ref('')
    const user = reactive({ age: 20 })

    // 监听多个数据源
    watch(
      [count, name, () => user.age], // 数组形式传入多个数据源
      ([newCount, newName, newAge], [oldCount, oldName, oldAge]) => {
        console.log('count changed:', newCount, oldCount)
        console.log('name changed:', newName, oldName)
        console.log('age changed:', newAge, oldAge)
        // 执行相关操作
      }
    )

    return { count, name, user }
  }
}
  1. 使用 watchEffect自动追踪依赖
javascript 复制代码
import { ref, watchEffect } from 'vue'

export default {
  setup() {
    const count = ref(0)
    const name = ref('')
    const active = ref(false)

    watchEffect(() => {
      // 这里会自动追踪所有使用到的响应式数据
      console.log('数据变化:', count.value, name.value, active.value)
      // 执行相关操作
    })

    return { count, name, active }
  }
}

3. 监听对象多个属性

javascript 复制代码
import { reactive, watch } from 'vue'

export default {
  setup() {
    const state = reactive({
      count: 0,
      name: '',
      active: false
    })

    // 监听对象多个属性
    watch(
      () => [state.count, state.name],
      ([newCount, newName], [oldCount, oldName]) => {
        console.log('count or name changed')
      }
    )

    return { state }
  }
}
相关推荐
WooaiJava1 分钟前
AI 智能助手项目面试技术要点总结(前端部分)
javascript·大模型·html5
LYFlied5 分钟前
从 Vue 到 React,再到 React Native:资深前端开发者的平滑过渡指南
vue.js·react native·react.js
爱喝白开水a20 分钟前
前端AI自动化测试:brower-use调研让大模型帮你做网页交互与测试
前端·人工智能·大模型·prompt·交互·agent·rag
Never_Satisfied21 分钟前
在JavaScript / HTML中,关于querySelectorAll方法
开发语言·javascript·html
董世昌4121 分钟前
深度解析ES6 Set与Map:相同点、核心差异及实战选型
前端·javascript·es6
B站_计算机毕业设计之家35 分钟前
豆瓣电影数据采集分析推荐系统 | Python Vue Flask框架 LSTM Echarts多技术融合开发 毕业设计源码 计算机
vue.js·python·机器学习·flask·echarts·lstm·推荐算法
WeiXiao_Hyy1 小时前
成为 Top 1% 的工程师
java·开发语言·javascript·经验分享·后端
吃杠碰小鸡1 小时前
高中数学-数列-导数证明
前端·数学·算法
kingwebo'sZone1 小时前
C#使用Aspose.Words把 word转成图片
前端·c#·word
xjt_09012 小时前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js