vue 判断对象属性是否变化 踩坑日记

本文探讨了在JavaScript中如何有效地监测对象属性的变化,特别是在表单编辑场景下。作者指出,简单使用watch无法准确判断对象是否改变,而直接赋值可能导致引用问题。正确的做法是使用`Object.assign()`创建对象副本,然后通过深度监听来比较新旧值。当属性发生改变时,更新编辑状态。
摘要由CSDN通过智能技术生成

小坑,记录一下:
我更改了某个属性,然后又复原的话,这样对象也是没有改变的
如果只是简单的监听watch肯定不行,每个属性进行判断也不尽人意,

首先想到的肯定是watch

先自定义一个对象formOrigin 赋值
错:this.formOrigin = this.form
对:this.formOrigin = Object.assign({},this.form)

watch监听(isEdit默认为true 没有更改)

form:{
         handler(newValue,oldValue){
             if(oldValue&&oldValue.id) {
               for(let key in this.formOrigin) {
                 if(newValue[key]!= this.formOrigin[key]&&newValue[key]!='') {
                  this.isEdit = false
                  break;
                 }
                 else {
                   this.isEdit = true
                 }
               }
              
      }
          },
        deep:true,//只要当form中的值改变就会触发这个函数且,newValue,oldValue两个参数值相同;
       }
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值