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

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

查看所有标签

猜你喜欢:

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

JavaScript忍者秘籍

JavaScript忍者秘籍

John Resig、Bear Bibeault / 徐涛 / 人民邮电出版社 / 2015-10 / 69.00

JavaScript语言非常重要,相关的技术图书也很多,但没有任何一本书对JavaScript语言的重要部分(函数、闭包和原型)进行深入、全面的介绍,也没有任何一本书讲述跨浏览器代码的编写。本书是jQuery库创始人编写的一本深入剖析JavaScript语言的书。 本书共分四个部分,从准入训练、见习训练、忍者训练和火影训练四个层次讲述了逐步成为JavaScript高手的全过程。全书从高级We......一起来看看 《JavaScript忍者秘籍》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

Markdown 在线编辑器
Markdown 在线编辑器

Markdown 在线编辑器

HSV CMYK 转换工具
HSV CMYK 转换工具

HSV CMYK互换工具