vue.set向?qū)ο罄镌黾佣鄬訑?shù)組屬性不生效問(wèn)題及解決
屬性多層數(shù)組數(shù)據(jù)的添加修改
為什么需要使用Vue.set?
vue中不能檢測(cè)到數(shù)組的一些變化
比如一下兩種:
1、數(shù)組長(zhǎng)度的變化 vm.arr.length = 100
2、數(shù)組通過(guò)索引值修改內(nèi)容 vm.arr[1] = ‘aa’
那么為什么vue要做成這樣,不去監(jiān)聽數(shù)組的變化,數(shù)組在日常中使用頻率還是比較高的,這個(gè)問(wèn)題其實(shí)尤大說(shuō)過(guò),是為了性能,假設(shè)我們新建了一個(gè)數(shù)組,長(zhǎng)度是1000 但是只使用了前幾個(gè) ,去實(shí)現(xiàn)頁(yè)面的響應(yīng)式監(jiān)聽,從數(shù)組改變到頁(yè)面輸出一共需要遍歷兩遍數(shù)組,會(huì)增加性能消耗,這可能就是不去監(jiān)聽某一項(xiàng)數(shù)組數(shù)據(jù)變化的原因吧。
以下是vue observer的的源碼,判斷是數(shù)組了,會(huì)停止對(duì)數(shù)據(jù)屬性的監(jiān)測(cè)。

所以vue提供了Vue.set 方法彌補(bǔ)這些不足,Vue.set同vm.$set(target,key,value):可以動(dòng)態(tài)的給數(shù)組、對(duì)象添加和修改數(shù)據(jù),并更新視圖中數(shù)據(jù)的顯示。
vue在構(gòu)造函數(shù)new Vue()時(shí),就通過(guò)Object.defineProperty中的getter和setter 這兩個(gè)方法,完成了對(duì)數(shù)據(jù)的綁定。
所以直接通過(guò)vm.arr[1] = ‘aa’的方法,無(wú)法修改值去觸發(fā)vue中視圖的更新,必須還得通過(guò)Object.defineProperty的方法去改變,而Vue.set()就封裝了js底層的Object.defineProperty方法。
所以我們需要利用Vue.set() 響應(yīng)式新增與修改數(shù)據(jù)?! ?/p>
最近項(xiàng)目中使用到了樹形表格
即多層嵌套的數(shù)據(jù),類似于這樣的頁(yè)面展示。
數(shù)據(jù)結(jié)構(gòu)如下:
obj:[
{
id:'1',
type:'1',
children:[
{
id:'1-1',
type:'1-1',
}
]
}
]

在每一層數(shù)據(jù)的數(shù)據(jù)量都比較大的時(shí)候,不能使用一次性加載所有數(shù)據(jù),需要優(yōu)化加載,點(diǎn)擊table的expand,即@expand-change方法獲取下一層數(shù)據(jù),那么就需要給下一層數(shù)據(jù)增加children屬性
那么我們肯定會(huì)想到一下幾種方法:
- 第一種:
this.$set(this.obj[index],‘children',[…res.items])
- 第二種:
this.obj[index].children = [] this.obj[index].children.splice(0,0,…res.items) //或者push方法
- 第三種:
使用foreach方法,循環(huán)res.items使用
this.$set(this.obj[index].children,index,res.items[index])
我使用了這幾種方法,甚至是組合使用了,但是結(jié)果不是很好,數(shù)據(jù)是增加上了,但是并沒(méi)有響應(yīng)式的增加上,頁(yè)面都沒(méi)有展示出相應(yīng)的數(shù)據(jù),查看結(jié)構(gòu)時(shí),發(fā)現(xiàn)到第三層的時(shí)候,增加的children已經(jīng)沒(méi)有{ob:Observer},ob_: Observer是vue這個(gè)框架對(duì)數(shù)據(jù)設(shè)置的監(jiān)控器,有這個(gè)屬性,才能監(jiān)聽到數(shù)據(jù)的變化。
找了很久都不可以。最終嘗試了以下方法才得以解決:
//給第三層增加數(shù)據(jù)
this.$set(this.obj[level1Index].children[level2Index],'children',[])
//使用foreach 將數(shù)組的每一項(xiàng)添加為響應(yīng)式數(shù)據(jù)
res.items.forEach((item,index)=>{
this.obj[level1Index].children[level2Index]
this.$set(this.obj[level1Index].children[level2Index].children,index,item)
})
首先先添加children數(shù)組為響應(yīng)式,再去將數(shù)組中的每一項(xiàng)也添加為響應(yīng)式,頁(yè)面變可以正常顯示啦 。
向?qū)ο髷?shù)組中添加新屬性
this.rightMenuList.forEach(ele=>{
?? ??? ??? ??? ??? ?this.$set(ele, 'carInfo', data.carInfo)
?? ??? ??? ??? ?})this.tableColums.forEach(res=>{
?? ??? ??? ??? ?this.$set(this.exportParams,res.id,"");
?? ??? ??? ?})以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
vue3中各種類型文件進(jìn)行預(yù)覽功能實(shí)例
在vue移動(dòng)端項(xiàng)目中經(jīng)常遇到這樣的需求,對(duì)一些上傳的附件可以點(diǎn)擊之后在線預(yù)覽,所以下面這篇文章主要給大家介紹了關(guān)于vue3中各種類型文件進(jìn)行預(yù)覽功能的相關(guān)資料,需要的朋友可以參考下2021-09-09
vue項(xiàng)目中定時(shí)器無(wú)法清除的原因解決
頁(yè)面有定時(shí)器,并且定時(shí)器在離開頁(yè)面時(shí),有清除,本文主要介紹了vue項(xiàng)目中定時(shí)器無(wú)法清除的原因解決,具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02
淺談Vue3 Composition API如何替換Vue Mixins
這篇文章主要介紹了淺談Vue3 Composition API如何替換Vue Mixins,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-04-04
vue組件之間通信實(shí)例總結(jié)(點(diǎn)贊功能)
這篇文章主要介紹了vue組件之間通信,結(jié)合實(shí)例形式分析了vue父子組件、兄弟組件之間通信的原理、實(shí)現(xiàn)方法,并給出了一個(gè)類似點(diǎn)贊功能的總結(jié)實(shí)例,需要的朋友可以參考下2018-12-12
vue實(shí)現(xiàn)一拉到底的滑動(dòng)驗(yàn)證
這篇文章主要為大家詳細(xì)介紹了vue簡(jiǎn)單的一拉到底的滑動(dòng)驗(yàn)證,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-07-07
vue實(shí)現(xiàn)商品購(gòu)物車全選反選
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)商品購(gòu)物車全選反選,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04
vuex實(shí)現(xiàn)登錄狀態(tài)的存儲(chǔ),未登錄狀態(tài)不允許瀏覽的方法
下面小編就為大家分享一篇vuex實(shí)現(xiàn)登錄狀態(tài)的存儲(chǔ),未登錄狀態(tài)不允許瀏覽的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-03-03

