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']);

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

查看所有标签

猜你喜欢:

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

具体数学

具体数学

Ronald L.Graham、Oren Patashnik、Donald E.Knuth / 张凡、张明尧 / 人民邮电出版社 / 2013-4-1 / 99.00元

本书介绍了计算机的数学基础,内容涉及求和、取整函数、数论、二项式系数、特殊数、母函数(发生函数)、离散概率、渐近等等,面向从事计算机科学、计算数学、计算技术诸方面工作的人员,以及高等院校相关专业的师生。一起来看看 《具体数学》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

SHA 加密
SHA 加密

SHA 加密工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换