欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue.set向?qū)ο罄镌黾佣鄬訑?shù)組屬性不生效問題及解決

 更新時間:2022年04月20日 14:34:04   作者:Vincent.TM  
這篇文章主要介紹了vue.set向?qū)ο罄镌黾佣鄬訑?shù)組屬性不生效問題及解決,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

屬性多層數(shù)組數(shù)據(jù)的添加修改

為什么需要使用Vue.set?

vue中不能檢測到數(shù)組的一些變化

比如一下兩種:

1、數(shù)組長度的變化 vm.arr.length = 100  

2、數(shù)組通過索引值修改內(nèi)容 vm.arr[1] = ‘aa’

那么為什么vue要做成這樣,不去監(jiān)聽數(shù)組的變化,數(shù)組在日常中使用頻率還是比較高的,這個問題其實尤大說過,是為了性能,假設(shè)我們新建了一個數(shù)組,長度是1000 但是只使用了前幾個 ,去實現(xiàn)頁面的響應式監(jiān)聽,從數(shù)組改變到頁面輸出一共需要遍歷兩遍數(shù)組,會增加性能消耗,這可能就是不去監(jiān)聽某一項數(shù)組數(shù)據(jù)變化的原因吧。

以下是vue observer的的源碼,判斷是數(shù)組了,會停止對數(shù)據(jù)屬性的監(jiān)測。

所以vue提供了Vue.set 方法彌補這些不足,Vue.set同vm.$set(target,key,value):可以動態(tài)的給數(shù)組、對象添加和修改數(shù)據(jù),并更新視圖中數(shù)據(jù)的顯示。

vue在構(gòu)造函數(shù)new Vue()時,就通過Object.defineProperty中的getter和setter 這兩個方法,完成了對數(shù)據(jù)的綁定。

所以直接通過vm.arr[1] = ‘aa’的方法,無法修改值去觸發(fā)vue中視圖的更新,必須還得通過Object.defineProperty的方法去改變,而Vue.set()就封裝了js底層的Object.defineProperty方法。

所以我們需要利用Vue.set() 響應式新增與修改數(shù)據(jù)。  

最近項目中使用到了樹形表格

即多層嵌套的數(shù)據(jù),類似于這樣的頁面展示。

數(shù)據(jù)結(jié)構(gòu)如下:

obj:[
        {
          id:'1',
          type:'1',
          children:[
            {
              id:'1-1',
              type:'1-1',
            }
          ]
        }
      ]

在每一層數(shù)據(jù)的數(shù)據(jù)量都比較大的時候,不能使用一次性加載所有數(shù)據(jù),需要優(yōu)化加載,點擊table的expand,即@expand-change方法獲取下一層數(shù)據(jù),那么就需要給下一層數(shù)據(jù)增加children屬性

那么我們肯定會想到一下幾種方法:

  • 第一種:
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ù)是增加上了,但是并沒有響應式的增加上,頁面都沒有展示出相應的數(shù)據(jù),查看結(jié)構(gòu)時,發(fā)現(xiàn)到第三層的時候,增加的children已經(jīng)沒有{ob:Observer},ob_: Observer是vue這個框架對數(shù)據(jù)設(shè)置的監(jiān)控器,有這個屬性,才能監(jiān)聽到數(shù)據(jù)的變化。

找了很久都不可以。最終嘗試了以下方法才得以解決:

//給第三層增加數(shù)據(jù)
this.$set(this.obj[level1Index].children[level2Index],'children',[])
//使用foreach 將數(shù)組的每一項添加為響應式數(shù)據(jù)
res.items.forEach((item,index)=>{
	this.obj[level1Index].children[level2Index]
	this.$set(this.obj[level1Index].children[level2Index].children,index,item)
})

首先先添加children數(shù)組為響應式,再去將數(shù)組中的每一項也添加為響應式,頁面變可以正常顯示啦 。

向?qū)ο髷?shù)組中添加新屬性

this.rightMenuList.forEach(ele=>{
?? ??? ??? ??? ??? ?this.$set(ele, 'carInfo', data.carInfo)
?? ??? ??? ??? ?})
this.tableColums.forEach(res=>{
?? ??? ??? ??? ?this.$set(this.exportParams,res.id,"");
?? ??? ??? ?})

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 一文帶你了解vite對瀏覽器的請求做了什么

    一文帶你了解vite對瀏覽器的請求做了什么

    Vite是一種新型前端構(gòu)建工具,能夠顯著提升前端開發(fā)體驗,下面這篇文章主要給大家介紹了關(guān)于vite對瀏覽器的請求做了什么的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2021-12-12
  • Vue ECharts餅圖實現(xiàn)方法詳解

    Vue ECharts餅圖實現(xiàn)方法詳解

    這篇文章主要介紹了在vue.js中,使用echarts組件,創(chuàng)建一個餅圖,并且獲取餅圖的數(shù)據(jù)和屬性,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習吧
    2022-12-12
  • element可編輯表格驗證問題解決

    element可編輯表格驗證問題解決

    本文主要介紹了element可編輯表格驗證問題,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-05-05
  • vue中vant組件樣式失效問題及解決

    vue中vant組件樣式失效問題及解決

    這篇文章主要介紹了vue中vant組件樣式失效問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • Vue使用Three.js加載glTF模型的方法詳解

    Vue使用Three.js加載glTF模型的方法詳解

    這篇文章主要給大家介紹了關(guān)于Vue使用Three.js加載glTF模型的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家學習或者使用Vue具有一定的參考學習價值,需要的朋友們下面來一起學習學習吧
    2020-06-06
  • Element-ui樹形控件el-tree自定義增刪改和局部刷新及懶加載操作

    Element-ui樹形控件el-tree自定義增刪改和局部刷新及懶加載操作

    這篇文章主要介紹了Element-ui樹形控件el-tree自定義增刪改和局部刷新及懶加載操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-08-08
  • 使用vux實現(xiàn)上拉刷新功能遇到的坑

    使用vux實現(xiàn)上拉刷新功能遇到的坑

    最近公司在研發(fā)app,選擇了基于Vue框架的vux組件庫,現(xiàn)總結(jié)在實現(xiàn)上拉刷新功能遇到的坑,感興趣的朋友參考下吧
    2018-02-02
  • 前端XSS攻擊場景詳解與Vue.js處理XSS的方法(vue-xss)

    前端XSS攻擊場景詳解與Vue.js處理XSS的方法(vue-xss)

    這篇文章主要給大家介紹了關(guān)于前端XSS攻擊場景與Vue.js使用vue-xss處理XSS的方法,介紹了實際工作中渲染數(shù)據(jù)時遇到XSS攻擊時的防范措施,以及解決方案,需要的朋友可以參考下
    2024-02-02
  • vuex頁面刷新數(shù)據(jù)丟失問題的四種解決方式

    vuex頁面刷新數(shù)據(jù)丟失問題的四種解決方式

    vuex是大家使用vue時大多數(shù)都會選擇的,但是當頁面刷新之后vuex數(shù)據(jù)會丟失,下面這篇文章主要給大家介紹了關(guān)于vuex頁面刷新數(shù)據(jù)丟失問題的四種解決方式,需要的朋友可以參考下
    2022-02-02
  • Vue 動態(tài)添加路由及生成菜單的方法示例

    Vue 動態(tài)添加路由及生成菜單的方法示例

    這篇文章主要介紹了Vue 動態(tài)添加路由及生成菜單的方法示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-06-06

最新評論