Vue3监听

监听有多种方式实现,具体看对应的template部分和对应的js部分

template部分
<template>
  <h1>方式一:监听一个属性</h1>
  <p>求和:{{ sum }}</p>
  <button @click="sum++">方式一点我加1</button><br />


  ------------------------------------------------------------------------------------<br />
  <h2>方式二:监听多个属性</h2>
  <p>{{ tipsmessage }}</p>
  <button @click="tipsmessage += 1">点我拼接1</button><br />


  ------------------------------------------------------------------------------------<br />
  <h1>方式三:监听对象</h1>
  <p>姓名:{{ obj.name }}</p>
  <p>年龄:{{ obj.age }}</p>
  <button @click="obj.age++">点我加年龄</button><br />


  ------------------------------------------------------------------------------------<br />
  <h1>方式四:监听对象某一个属性变化</h1>
  <p>薪资:{{ obj.test.salary }}</p>
  <p>工作年限:{{ obj.test.year }}</p>
  <button @click="obj.test.salary += 1000">点我涨薪</button>
  <button @click="obj.test.year++">点我添加工作年限</button>
  <br />
</template>

JS部分
    let sum = ref(122);
    let tipsmessage = ref("hello");
    const obj = reactive({
      name: "老王",
      age: "50",
      test: {
        salary: 3000,
        year: 1,
      },
    });
       // 方式一:监听单个基本数据类型(ref)
       		此处代码看对应示例
       		
       // 方式二:监多个基本数据类型(ref)
		   此处代码看对应示例
		   
	   // 方式三:监听对象(reactive)
			此处代码看对应示例
			
	   // 方式四:监听对象中某一个属性变化(reactive)
	   		此处代码看对应示例
	   		
	   // 方式五:监视对象中某几个属性(reactive)
	   		此处代码看对应示例
	   		
	   //  方式六:监视对象中的某一个对象 但我操作这某一对象里面的某一个属性obj.test(reactive)
	   		此处代码看对应示例
	

-----------------------重点来了----------------------

方式一:监听单个基本数据类型(ref)
  watch(sum, (newVal, oldValue) => {
     	console.log(newVal, oldValue);
  });
方式二:监多个基本数据类型(ref)
 watch([sum, tipsmessage], (newVal, oldValue) => {
      // [122, 'hello1']监听出来结果发现新的值和旧的值都是数组
      console.log(newVal, oldValue);
 });
方式三:监听对象(reactive)
 vue3当前存在问题:
 1.reactive和ref响应式使用proxy代理无法正确监听并获取对象旧的值
 2.强制开启深度监听,关闭无效(deep配置无效)
watch(
      obj,
      (newVal, oldValue) => {
        // newVal=> {name: '老王', age: 52} oldValue=>{name: '老王', age: 52}
        console.log(newVal, oldValue);
      },
      { deep: false }
);
方式四:监听对象中某一个属性变化(reactive)
 watch(
   () => obj.test.salary,
      (newVal, oldValue) => {
        console.log(newVal, oldValue);
      }
); 
方式五:监听对象中某几个属性(reactive)
监听属性salary和year
 // 薪资和年龄示例
watch([() => obj.test.salary, () => obj.test.year], (newVal, oldValue) => {
      console.log(newVal, oldValue);
      //[4000, 1][3000, 1]
      const arr = ["salary", "year"];
      for (let i = 0; i < newVal.length; i++) {
        if (newVal[i] !== oldValue[i]) {
          // 1年工作经验 3000 每年涨薪1000
          switch (arr[i]) {
            case "salary":
              obj.test.year = (obj.test[arr[i]] - 3000) / 1000 + 1;
              break;
            case "year":
              obj.test.salary = (obj.test[arr[i]] - 1) * 1000 + 3000;
              break;
          }
        }
      }
    });
方式六:监视对象中的某一个对象 但我操作这某一对象里面的某一个属性obj.test(reactive)

注意:这种方式需要开启深度监听deep:true才能监视到某一对象属性的变化,此处deep配置有

 watch(
      () => obj.test,
      (newVal, oldValue) => {
        console.log(newVal, oldValue, "啊哈哈哈");
        //{salary: 3000, year: 2} {salary: 3000, year: 2} '啊哈哈哈'
      },
      { deep: true }
    );
    return { sum, tipsmessage, obj };
  },
};

注意点: 使用ref的响应式watch监听

  1. ref定义的基本类型使用watch监听时候不需要.value
    示例:
 watch(sum, (newVal, oldValue) => {
      console.log(newVal, oldValue);
 });

  1. ref定义对象类型使用watch监听对象时监听的对象外层可以使用2个方式
    示例:
 const obj = ref({
      name: "老王",
      age: "50",
      test: {
        salary: 3000,
        year: 1,
      },
 });

使用.value监听

   watch(obj.value, (newVal, oldValue) => {
      console.log(newVal, oldValue);
    });

开启深度监听deep:true

  watch(obj, (newVal, oldValue) => {
      console.log(newVal, oldValue);
    },{deep:true});
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue3中,可以通过使用`watch`函数来监听数组的变化。Vue3中的`watch`函数可以接收两个参数,第一个参数是要监听的数据,第二个参数是回调函数,当数据发生变化时会触发该回调函数。对于数组的监听,可以使用`watch`函数的`deep`选项来进行深度监听,以便捕捉到数组的变化。例如: ```javascript let arr = ref(\[\]); // 定义一个响应式的数组 watch(arr, (value) => { console.log('数组发生变化', value); }, { deep: true }); ``` 在上述代码中,我们使用`ref`函数将数组转换为响应式数据,然后使用`watch`函数监听该数组的变化。当数组发生变化时,回调函数会被触发,并打印出数组的新值。通过设置`deep`选项为`true`,可以实现对数组的深度监听。这样,无论是通过赋值、splice方法还是push方法改变数组,都能够被监听到。 需要注意的是,在Vue3中,监听数组的变化需要使用`ref`函数将数组转换为响应式数据,而不是直接使用普通的数组。这样才能确保数组的变化能够被Vue3监听到。 #### 引用[.reference_title] - *1* [Vue3为何使用Proxy实现数据监听](https://blog.csdn.net/Gary_888/article/details/125860568)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [vue3监听变量(包括对象、数组的特殊用法)](https://blog.csdn.net/qq_39157025/article/details/131048908)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insertT0,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值