vue和react动态改变对象或者数组

vue动态改变对象或者数组

从Vue官网上了解到,受现代js的限制,Vue无法检测到对象属性的添加或删除,那么我们可以通过以下几种方式去添加对象或者数组的属性:

  1. 改变对象属性

    • 可以使用全局Vue.set(this.someObj, key, value)方法向嵌套对象添加响应式属性

    • 可以使用this.$set(this.someObj, key, value),这是全局Vue.set方法的别名

    • 可以使用this.someObj = Object.assign({}, this.someObj, {key:value})(不了解Object.assign()方法的建议先看MDN:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Object/assign

    • 最后举个栗子:

      <template>
       <div class="hello">
         <h1>{{ msg }}</h1>
         <h2>{{JSON.stringify(obj)}}</h2>
       </div>
      </template>
      ​
      <script>
      import Vue from "vue";
      export default {
       name: "HelloWorld",
       data() {
         return {
           msg: "Welcome to Your Vue.js App",
           obj: {
             a: 1
           }
         }
       },
       mounted() {
         Vue.set(this.obj, "b", 2);
         this.$set(this.obj, "c", 3);
         this.obj = Object.assign({}, this.obj, { d: 4 });
       }
      };
      </script>
      //页面上看到的结果是{"a":1,"b":2,"c":3,"d":4}
      
      
    • 以上方法都要注意对象不能是 Vue 实例(在组件中Vue实例指的就是this),或者 Vue 实例的根数据对象(在组件中指的就是根组件里为对象时候的data)。

  2. 改变数组

    当你利用索引直接设置一个数组项时,例如:this.arr[index] = newValue;当你修改数组的长度时,例如:this.arr.length = newLength,Vue不能检测到该数组的变动,我们可以利用以下方法触发更新:

    • 会改变原数组的一些方法,Vue也能观察到数组的变化触发视图更新,这些方法如下:

      push()
      pop()
      shift()
      unshift()
      splice()
      sort()
      reverse()
      
      
    • 重新赋值数组,像filter(), concat(), slice()这些方法不会改变原数组,但总是返回一个新数组,那么我们可以利用新数组替换旧数组,如下代码:

      this.arr = this.arr.filter((item,index)=>{
       return item.id != 1
      })
      
    • 可以通过Vue.set(this.arr, index, newValue)方法改变数组的值

    • 可以通过this.arr.splice(index, 1, newValue)方法改变数组的值,不了解splice()方法的可以自行参考MDN:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Array/splice

    • 如果你想修改数组长度,可以通过this.arr.splice(newLength)方法实现

  3. 讲一个实际项目中我们容易遇上的栗子,比如一个列表,我们需要点击一个按钮后改变某一列的状态以此来做一些判断,那么我们可以如下实现:

    handleClick(index){
     this.arr.splice(index,1,{
       ...this.arr[index],
       flag:true //相当于新增一个标记方便对某一列进行一些逻辑判断
     })
    }
    
    

参考vue官网列表渲染:https://cn.vuejs.org/v2/guide/list.html

参考vue官网深入响应式原理:https://cn.vuejs.org/v2/guide/reactivity.html

react动态改变对象或者数组

  1. 修改对象中的某项

    this.setState({
       obj: {
         ...obj,
         key: value
       }
    })
    
    
  2. 修改数组中任意一项的值

    //法一
    updateArray(index, key, value){
      const clone = this.state.arr.slice();
      clone[index][key] = value;
      this.setState({
        arr: clone
      });
    }
    
    //法二 //不推荐,官方提醒,应该把this.state当成不可变变量
    updateArray(index, key, value){
      let { arr } = this.state
      arr[index][key] = value;
      this.setState({
        arr
      });
    }
    ​
    //法三
    updateArray(index, key, value){
      this.setState({
        arr: this.state.arr.map((item, _index) =>
        _index === index ? { ...item, [key]: value } : item
        )
      })
     }
    
    
  3. 在数组任意位置添加一项

    updateArray(index, value){
      let { arr } = this.state
      arr.splice(index, 0, value);
      this.setState({
        arr
      });
    }
    
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容