vue3中watch监听不同数据源的方法总结

 更新时间:2026年03月26日 08:57:47   作者:送鱼的老默  
这篇文章主要为大家详细介绍了vue3中watch监听不同数据源的常用方法,文中的示例代码讲解详细,具有一定的借鉴价值,大家可以根据自己的需要进行选择

在 Vue 3 中,watch 监听不同数据源的方式有所不同

1. 监听单个 ref

import { ref, watch } from 'vue'

const count = ref(0)

// 直接传入 ref
watch(count, (newVal, oldVal) => {
  console.log('count 变化:', newVal, oldVal)
})

// 或者使用 getter 函数
watch(() => count.value, (newVal, oldVal) => {
  console.log('count 变化:', newVal, oldVal)
})

2. 监听多个 ref

import { ref, watch } from 'vue'

const count = ref(0)
const name = ref('John')

// 方式1:使用数组
watch([count, name], ([newCount, newName], [oldCount, oldName]) => {
  console.log('count 变化:', newCount, oldCount)
  console.log('name 变化:', newName, oldName)
})

// 方式2:使用 getter 数组
watch(
  [() => count.value, () => name.value],
  ([newCount, newName], [oldCount, oldName]) => {
    console.log('多个数据变化')
  }
)

3. 监听单个 reactive

import { reactive, watch } from 'vue'

const state = reactive({
  count: 0,
  name: 'John'
})

// ❌ 错误:直接传入 reactive 对象无法监听到内部属性的变化
watch(state, (newVal, oldVal) => {
  console.log('不会触发') // 深度监听时才会触发
})

// ✅ 正确:使用 getter 函数监听特定属性
watch(
  () => state.count,
  (newVal, oldVal) => {
    console.log('count 变化:', newVal, oldVal)
  }
)

// ✅ 深度监听整个 reactive 对象
watch(
  () => state,
  (newVal, oldVal) => {
    console.log('state 任何属性变化都会触发')
  },
  { deep: true }
)

4. 监听多个 reactive 数据

import { reactive, watch } from 'vue'

const state1 = reactive({ count: 0 })
const state2 = reactive({ name: 'John' })

// 方式1:使用 getter 数组
watch(
  [() => state1.count, () => state2.name],
  ([newCount, newName], [oldCount, oldName]) => {
    console.log('数据变化')
  }
)

// 方式2:深度监听整个 reactive 对象(不推荐)
watch(
  [() => state1, () => state2],
  ([newState1, newState2], [oldState1, oldState2]) => {
    // 注意:oldState1 和 newState1 指向同一个对象
    console.log('状态变化')
  },
  { deep: true }
)

5. 混合监听 ref 和 reactive

import { ref, reactive, watch } from 'vue'

const count = ref(0)
const state = reactive({ name: 'John', age: 18 })

watch(
  [count, () => state.name, () => state.age],
  ([newCount, newName, newAge], [oldCount, oldName, oldAge]) => {
    console.log('混合数据变化')
  }
)

6. 监听响应式对象的属性

import { reactive, watch } from 'vue'

const user = reactive({
  info: {
    name: 'John',
    address: {
      city: 'Beijing'
    }
  }
})

// 监听嵌套属性
watch(
  () => user.info.address.city,
  (newVal, oldVal) => {
    console.log('城市变化:', newVal, oldVal)
  }
)

// 深度监听整个对象
watch(
  () => user,
  (newVal, oldVal) => {
    console.log('user 任何变化')
  },
  { deep: true }
)

总结对比

数据源监听方式注意事项
单个 refwatch(count, callback)直接传入即可
多个 refwatch([ref1, ref2], callback)使用数组形式
单个 reactive 属性watch(() => state.prop, callback)必须使用 getter
多个 reactive 属性watch([() => state.prop1, () => state.prop2], callback)使用 getter 数组
整个 reactivewatch(() => state, callback, { deep: true })必须深度监听

最佳实践建议

  • 优先使用 getter 函数,特别是监听 reactive 对象的属性
  • 避免深度监听大型对象,可能会影响性能
  • 注意旧值的引用问题:对于 reactive 对象,旧值可能与新值相同(因为引用未变)

到此这篇关于vue3中watch监听不同数据源的方法总结的文章就介绍到这了,更多相关vue3 watch监听数据源内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Vue中使用pdf.js实现PDF文档展示功能实例

    Vue中使用pdf.js实现PDF文档展示功能实例

    最近做项目遇到在线预览和下载pdf文件,试了多种pdf插件,例如jquery.media.js(ie无法直接浏览),最后选择了pdf.js插件,这篇文章主要介绍了Vue中使用pdf.js实现PDF文档展示功能的相关资料,需要的朋友可以参考下
    2025-04-04
  • vue3+elementUI如何动态修改Loading中提示文字

    vue3+elementUI如何动态修改Loading中提示文字

    这篇文章主要介绍了vue3+elementUI如何动态修改Loading中提示文字的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2025-05-05
  • 在Vue中实现页面状态保存的各种方法

    在Vue中实现页面状态保存的各种方法

    作为前端开发者,你一定遇到过这样的场景:用户在一个复杂的表单页面填写了大量信息,不小心刷新了页面或点击了返回按钮,所有数据都消失了!所以今天我们来深入探讨在 Vue 中实现页面状态保存的各种方法,需要的朋友可以参考下
    2026-01-01
  • 探讨Vue.js的组件和模板

    探讨Vue.js的组件和模板

    指令是Vue.js中一个重要的特性, 主要提供了一种机制将数据的变化映射为DOM行为。下面通过本文给大家分享Vue.js的组件和模板,需要的朋友参考下吧
    2017-10-10
  • vue+element使用动态加载路由方式实现三级菜单页面显示的操作

    vue+element使用动态加载路由方式实现三级菜单页面显示的操作

    这篇文章主要介绍了vue+element使用动态加载路由方式实现三级菜单页面显示的操作,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-08-08
  • 一篇文章,教你学会Vue CLI 插件开发

    一篇文章,教你学会Vue CLI 插件开发

    这篇文章主要介绍了Vue CLI插件开发,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-04-04
  • Vue3进行样式Scoped和Global的设置方法

    Vue3进行样式Scoped和Global的设置方法

    在 Vue 3 中,组件化开发成为了我们提升前端开发效率的利器,其中,样式的管理也是一个至关重要的部分,在 Vue 中,我们会经常使用两种样式作用域:Scoped 样式和 Global 样式,本文将通过示例代码来介绍Vue3如何进行样式Scoped和Global的设置,需要的朋友可以参考下
    2025-01-01
  • Vue代码分割懒加载的实现方法

    Vue代码分割懒加载的实现方法

    这篇文章主要给大家介绍了关于Vue代码分割懒加载的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-11-11
  • vue实现登录类型切换

    vue实现登录类型切换

    这篇文章主要为大家详细介绍了vue实现登录类型切换,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2021-04-04
  • Vue.js如何使用Socket.IO的示例代码

    Vue.js如何使用Socket.IO的示例代码

    这篇文章主要介绍了Vue.js如何使用Socket.IO的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09

最新评论