当前位置: 首页 > article >正文

vue3如何监听reactive对象是哪个属性发生的变化

在 Vue 3 中,如果你想监听 reactive 对象中的某个属性发生的变化,你可以使用 watch 函数进行监听。watch 函数允许你观察 reactive 对象的某个属性或者整个对象,并在变化时执行相应的操作。

1. 监听 reactive 对象的某个属性

如果你只想监听 reactive 对象的某个特定属性,可以直接在 watch 中传入该属性。

import { reactive, watch } from 'vue';

const state = reactive({
  name: 'John',
  age: 30,
  location: 'New York',
});

// 监听 name 属性的变化
watch(() => state.name, (newValue, oldValue) => {
  console.log(`Name changed from ${oldValue} to ${newValue}`);
});

2. 监听整个 reactive 对象并检查是哪一个属性发生了变化

如果你需要监听整个 reactive 对象,并确定到底是哪个属性发生了变化,可以通过对整个对象进行深度监听 (deep: true),然后手动检查哪个属性发生了变化。

import { reactive, watch } from 'vue';

const state = reactive({
  name: 'John',
  age: 30,
  location: 'New York',
});

// 监听整个对象的变化
watch(
  state,
  (newValue, oldValue) => {
    for (const key in newValue) {
      if (newValue[key] !== oldValue[key]) {
        console.log(`${key} changed from ${oldValue[key]} to ${newValue[key]}`);
      }
    }
  },
  { deep: true } // 深度监听
);

3. 监听多个属性

如果你需要监听多个特定的属性,你可以使用多个 watch,或者通过组合使用 computed 进行监听。

import { reactive, watch } from 'vue';

const state = reactive({
  name: 'John',
  age: 30,
  location: 'New York',
});

// 监听 name 和 age 属性的变化
watch(
  () => [state.name, state.age],
  ([newName, newAge], [oldName, oldAge]) => {
    if (newName !== oldName) {
      console.log(`Name changed from ${oldName} to ${newName}`);
    }
    if (newAge !== oldAge) {
      console.log(`Age changed from ${oldAge} to ${newAge}`);
    }
  }
);

4. 使用 toRefs 进行属性监听

你可以将 reactive 对象的属性转换为 ref,然后使用 watch 监听这些 ref

import { reactive, toRefs, watch } from 'vue';

const state = reactive({
  name: 'John',
  age: 30,
  location: 'New York',
});

const { name, age } = toRefs(state);

// 监听 name 属性的变化
watch(name, (newValue, oldValue) => {
  console.log(`Name changed from ${oldValue} to ${newValue}`);
});

// 监听 age 属性的变化
watch(age, (newValue, oldValue) => {
  console.log(`Age changed from ${oldValue} to ${newValue}`);
});

总结

  • 监听单个属性:使用 watch(() => state.name, ...) 监听特定属性的变化。
  • 监听整个对象:使用 watch(state, ...) 并结合 deep: true 深度监听整个对象,并手动检查哪些属性发生了变化。
  • 监听多个属性:可以通过数组或组合 computed 来监听多个属性的变化。
  • 使用 toRefs:将 reactive 对象的属性转换为 ref,然后分别进行监听。

这些方法可以帮助你灵活地监听 reactive 对象中的属性变化,根据实际需求选择合适的方式。


http://www.kler.cn/a/282520.html

相关文章:

  • 速通前端篇 —— HTML
  • 容器内的Jenkins使用docker部署服务,服务数据文件挂载问题
  • 【miniMax开放平台-注册安全分析报告-无验证方式导致安全隐患】
  • GitHub新手入门 - 从创建仓库到协作管理
  • 软件设计师 - 第1章 计算机网络概论
  • @Autowired 和 @Resource思考(注入redisTemplate时发现一些奇怪的现象)
  • 东华医疗协同办公系统templateFile接口存在任意文件读取漏洞 附POC
  • 我的电脑/资源管理器里无法显示新硬盘?
  • Lua收集请求日志
  • 全栈程序员 | 精通安卓、鸿蒙,小程序,Java、Vue.js、SpringBoot及更多技术
  • Git之1.7版本重要特性及用法实例(五十五)
  • 今日算法:蓝桥杯基础题之“微生物增殖”
  • 网络安全面试经验80篇
  • C#命名空间(Namespace)
  • 如何本地搭建 Whisper 语音识别模型?一文解决
  • Vulkan入门系列16 - 生成多级纹理贴图( Mipmaps)
  • Git之1.6版本重要特性及用法实例(五十四)
  • 请你学习:前端布局3 - flex
  • 实训day36(8.26)
  • 概率论与高等数学、线性代数的联系及应用
  • 虚幻5|技能栏优化(1)---优化技能UI,并添加多个技能
  • 问:JAVA接口和抽象类有哪些差异?
  • 四十五、【人工智能】【机器学习】- Robust Regression(稳健回归)
  • 骁龙CPU简介
  • 扩展——双向搜索
  • vagrant 创建虚拟机