国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

vue 數組和對象不能直接賦值情況和解決方法(推薦)

2019-11-19 15:04:55
字體:
來源:轉載
供稿:網友

Vue 不能檢測以下變動的數組:

當你利用索引直接設置一個項時,例如:vm.items[indexOfItem] = newValue

當你修改數組的長度時,例如:vm.items.length = newLength

當第一種情況需求時,可以使用this.$set(this.arr,index,newVal)

Vue 不能檢測對象屬性的添加或刪除:

  可以使用this.$set(this.person,'age',12)

     當需要添加多個對象時,Object.assign({},this.person,{age:12,name:'wee'})

PS:Vue實現對數組、對象的深拷貝、復制

當組件間傳遞對象時,由于此對象的引用類型指向的都是一個地址(除了基本類型跟null,對象之間的賦值,只是將地址指向同一個,而不是真正意義上的拷貝),如下

數組:

var a = [1,2,3];var b = a;b.push(4); // b中添加了一個4alert(a); // a變成了[1,2,3,4]

對象:

var obj = {a:10};var obj2 = obj;obj2.a = 20; // obj2.a改變了,alert(obj.a); // 20,obj的a跟著改變 

這就是由于對象類型直接賦值,只是將引用指向同一個地址,導致修改了obj會導致obj2也被修改

所以在vue中,如果多個組件引用了同一個對象作為數據,那么當其中一個組件改動對象數據時,其他對象的數據也會同步改動。有這種雙向綁定的需要的話,那么自然是最好的,但如果不需要這種綁定而希望各組件的對象數據之間相互獨立,即是互不關聯的對象副本的話,可以用下面的方法解決

computed: {    data: function () {      var obj={};      obj=JSON.parse(JSON.stringify(this.templateData)); //this.templateData是父組件傳遞的對象      return obj   }  }

總結

以上所述是小編給大家介紹的vue 數組和對象不能直接賦值情況和解決方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 武威市| 那曲县| 上犹县| 二连浩特市| 水城县| 松桃| 长岭县| 隆安县| 日土县| 融水| 姚安县| 平乐县| 吉林市| 芒康县| 台安县| 鲁山县| 东乡族自治县| 昂仁县| 志丹县| 谢通门县| 柏乡县| 抚顺市| 永宁县| 巫山县| 北流市| 七台河市| 芦溪县| 阿鲁科尔沁旗| 饶阳县| 蒲城县| 定兴县| 石狮市| 广平县| 玉林市| 青海省| 台中县| 娱乐| 益阳市| 赣州市| 本溪市| 嘉义市|