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 }
  }
}
相关推荐
Mintopia11 分钟前
Vite 发展现状与回顾:从“极致开发体验”到生态基础设施
前端
前端双越老师35 分钟前
前端面试常见的 10 个场景题
前端·面试·求职
孟祥_成都1 小时前
【全网最通俗!新手到AI全栈开发必读】 AI 是如何进化到大模型的
前端·人工智能·全栈
牛奶2 小时前
AI辅助开发的基础概念
前端·人工智能·ai编程
摸鱼的春哥2 小时前
Agent教程15:认识LangChain,Agent框架的王(上)
前端·javascript·后端
明月_清风3 小时前
自定义右键菜单:在项目里实现“选中文字即刻生成新提示”
前端·javascript
明月_清风3 小时前
告别后端转换:高质量批量导出实战
前端·javascript
刘发财7 小时前
弃用html2pdf.js,这个html转pdf方案能力是它的几十倍
前端·javascript·github
牛奶10 小时前
2026年大模型怎么选?前端人实用对比
前端·人工智能·ai编程
牛奶10 小时前
前端人为什么要学AI?
前端·人工智能·ai编程