Vue組件傳值過程中丟失數(shù)據(jù)的分析與解決方案
前言
在上一篇文章 JavaScript 中的兩種數(shù)據(jù)類型中,分別介紹了基本類型和引用類型,以及引用類型的淺拷貝與深拷貝。這里需要注意的是,該文章中深拷貝引用類型值的方法,并不是完美的,引用類型值中的某些屬性值,仍不能完整地復(fù)制到新的變量中。比如函數(shù)值,在深拷貝過程中,就會(huì)丟失。
問題
在實(shí)際項(xiàng)目中,假如使用了二次封裝的組件,并且封裝的組件內(nèi)部做了一些屬性值的深拷貝操作,就有極有可能因?yàn)閭魅氲膶傩灾凳且妙愋偷闹?,?dǎo)致丟失部分?jǐn)?shù)據(jù)。
舉例
以基于 el-table 封裝的 ak-table 組件為例:
往 ak-table 組件中傳入 row-key 屬性,該屬性可傳入一個(gè)函數(shù):Function(row),具體見官方文檔。

按理正常邏輯,傳入 ak-table 的屬性值應(yīng)該原封不動(dòng)地傳入到 el-table 組件中,但是奇怪的事情在這里發(fā)生了,我們傳入的函數(shù)在組件中消失了!

問題分析
首先傳入 ak-table 的 row-key 屬性的值,它是一個(gè)函數(shù),即引用類型值,那么根據(jù)文章開頭所說,如果對(duì)引用類型的值進(jìn)行一般的深拷貝操作,是會(huì)丟失函數(shù)和數(shù)組等數(shù)據(jù)的。
在 ak-table 中,找到 row-key 屬性,因?yàn)闆]有在 props 中定義,所以應(yīng)該是保存在組件的 attrs 屬性中。去到 mounted 方法,在此打印attrs屬性中。去到mounted方法,在此打印attrs 的值,看看拷貝前后的數(shù)據(jù)對(duì)比。

控制臺(tái)輸出
———————————————————————————————————————

問題到這里就很清晰了,首先,ak-table 組件內(nèi)部其實(shí)是想對(duì)傳進(jìn)來的屬性值做初始化操作,然后就對(duì) $attrs 進(jìn)行了深拷貝操作,拷貝之后就丟失了 row-key 屬性值,所以造成了數(shù)據(jù)丟失。
解決方案
對(duì)于傳入引用類型的值,直接通過子組件的 props 屬性接收來自父組件的值,然后不對(duì)傳進(jìn)來的值做處理,直接使用。
對(duì)于傳入引用類型的值,在拷貝時(shí)要‘特殊對(duì)待',把需要用到的屬性值遞歸拷貝到新的變量中。
總結(jié)
對(duì)于 JavaScript 中的基本類型和引用類型,以及對(duì)引用類型值拷貝的理解,是我們運(yùn)用這門語言進(jìn)行開發(fā)的基本技能。有時(shí)候常常因?yàn)榇中拇笠猓詾楹?jiǎn)單粗暴的拷貝一個(gè)變量,就以為得到了它的完全復(fù)制體,因而造成了某些數(shù)據(jù)‘消失不見'的靈異事件。這時(shí)可以參考文章的解決方案,這是我在項(xiàng)目開發(fā)中遇到過的問題,以此記錄,希望對(duì)您有幫助。
到此這篇關(guān)于Vue組件傳值過程中丟失數(shù)據(jù)的分析與解決方案的文章就介紹到這了,更多相關(guān)Vue組件傳值丟失數(shù)據(jù)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
參考鏈接:JavaScript深拷貝的一些坑
- vue實(shí)現(xiàn)tab切換的3種方式及切換保持?jǐn)?shù)據(jù)狀態(tài)
- 基于vue+echarts數(shù)據(jù)可視化大屏展示的實(shí)現(xiàn)
- vue基于Echarts的拖拽數(shù)據(jù)可視化功能實(shí)現(xiàn)
- vue 獲取到數(shù)據(jù)但卻渲染不到頁面上的解決方法
- Antd-vue Table組件添加Click事件,實(shí)現(xiàn)點(diǎn)擊某行數(shù)據(jù)教程
- vue+echarts+datav大屏數(shù)據(jù)展示及實(shí)現(xiàn)中國(guó)地圖省市縣下鉆功能
- vuex中遇到的坑,vuex數(shù)據(jù)改變,組件中頁面不渲染操作
- vue實(shí)現(xiàn)兩個(gè)組件之間數(shù)據(jù)共享和修改操作
- 淺析vue偵測(cè)數(shù)據(jù)的變化之基本實(shí)現(xiàn)
相關(guān)文章
Vue通過路由實(shí)現(xiàn)頁面間參數(shù)的傳遞
這篇文章主要介紹了Vue通過路由實(shí)現(xiàn)頁面間參數(shù)的傳遞,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-04-04
Vue3組件中g(shù)etCurrentInstance()獲取App實(shí)例,但是返回null的解決方案
這篇文章主要介紹了Vue3組件中g(shù)etCurrentInstance()獲取App實(shí)例,但是返回null的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-04-04
vue+Element-ui前端實(shí)現(xiàn)分頁效果
這篇文章主要為大家詳細(xì)介紹了vue+Element-ui前端實(shí)現(xiàn)分頁效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11
Vue項(xiàng)目全局配置頁面緩存之按需讀取緩存的實(shí)現(xiàn)詳解
這篇文章主要給大家介紹了關(guān)于Vue項(xiàng)目全局配置頁面緩存之實(shí)現(xiàn)按需讀取緩存的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起看看吧2018-08-08

