vue改变对象或数组时的刷新机制总结

栏目: 编程语言 · 发布时间: 5年前

内容简介:总结:1.数组更改值或者增加删除值,不会触发更新2.对象更改值可触发更新,增加或者删除属性不会触发更新。

总结:

1.数组更改值或者增加删除值,不会触发更新

2.对象更改值可触发更新,增加或者删除属性不会触发更新。

一、纯数组-------showArr:[true,true]

  1. 数组中元素直接赋值,---不触发刷新

    this.showArr[0]=!this.showArr[0];
  2. 数组修改后整体赋值,---不触发刷新

    var parr=this.showArr;
          parr[0]=!parr[0];
          this.showArr=parr;
  3. 数组重新复制出一份新的,修改后整体赋值,---可触发刷新

    var parr=this.showArr.slice(0);
          parr[0]=!parr[0];
          this.showArr=parr;
  4. 用$set赋值,---可触发刷新

    this.$set(this.showArr,0,!this.showArr[0])

二、纯对象-------showArr:{'showBool':true}

  1. 对象中元素直接赋值,---可触发刷新

    this.showArr['showBool']=!this.showArr['showBool'];
  2. 对象修改后整体赋值,---可触发刷新

    var parr=this.showArr;
           parr['showBool']=!parr['showBool'];
           this.showArr=parr;
  3. 用$set赋值,---可触发刷新

    this.$set(this.showArr,'showBool',!this.showArr['showBool']);

三、 对象数组-------showArr:[{'showBool':true},{'showBool':true}]

  1. 数组中元素直接赋值,---可触发刷新

    this.showArr[0]['showBool']=!this.showArr[0]['showBool'];
  2. 数组修改后整体赋值,---可触发刷新

    var parr=this.showArr;
           parr[0]['showBool']=!parr[0]['showBool'];
           this.showArr=parr;
  3. 数组重新复制出一份新的,修改后整体赋值,---可触发刷新

    var parr=this.showArr.slice(0);
           parr[0]['showBool']=!parr[0]['showBool'];
           this.showArr=parr;
  4. 用$set赋值,---可触发刷新

    this.$set(this.showArr[0],'showBool',!this.showArr[0]['showBool']);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

首席产品官1 从新手到行家

首席产品官1 从新手到行家

车马 / 机械工业出版社 / 2018-9-25 / 79

《首席产品官》共2册,旨在为产品新人成长为产品行家,产品白领成长为产品金领,最后成长为首席产品官(CPO)提供产品认知、能力体系、成长方法三个维度的全方位指导。 作者在互联网领域从业近20年,是中国早期的互联网产品经理,曾是周鸿祎旗下“3721”的产品经理,担任CPO和CEO多年。作者将自己多年来的产品经验体系化,锤炼出了“产品人的能力杠铃模型”(简称“杠铃模型”),简洁、直观、兼容性好、实......一起来看看 《首席产品官1 从新手到行家》 这本书的介绍吧!

CSS 压缩/解压工具
CSS 压缩/解压工具

在线压缩/解压 CSS 代码

SHA 加密
SHA 加密

SHA 加密工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具