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两个参数值相同;
       }
Vue判断对象属性的方法有多种。首先,我们可以使用比较运算符(如==)来判断两个对象属性是否一致。例如,在给定的代码中,我们可以使用`obj3.b == obj4.b`来判断`obj3`和`obj4`的`b`属性是否一致,如果一致则返回true,否则返回false。 另外,我们也可以使用`hasOwnProperty`方法来判断对象是否包含某一项属性。该方法可以用于判断一个对象是否包含指定的属性。例如,在给定的代码中,我们可以使用`obj1.hasOwnProperty('a')`来判断`obj1`是否包含`a`属性,如果包含则返回true,否则返回false。 此外,在Vue中,我们还可以使用`watch`来监听对象属性的改变。通过定义一个`watch`对象,并设置`handler`属性为一个函数,我们可以在指定属性发生改变时执行相应的逻辑。例如,在给定的代码中,我们可以通过`watch`来监听`form`对象属性的改变,当某个属性发生改变时,`handler`函数会被调用,并且会传入两个参数`newValue`和`oldValue`,我们可以在这个函数中根据需要进行判断。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [vue判断对象是否包含这一项和两个对象属性是否相等](https://blog.csdn.net/weixin_46409887/article/details/122555084)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [vue 判断对象属性是否变化 日记](https://blog.csdn.net/m0_49578914/article/details/122327816)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值