Vue組件傳值過程中丟失數(shù)據(jù)的分析與解決方案
前言
在上一篇文章 JavaScript 中的兩種數(shù)據(jù)類型中,分別介紹了基本類型和引用類型,以及引用類型的淺拷貝與深拷貝。這里需要注意的是,該文章中深拷貝引用類型值的方法,并不是完美的,引用類型值中的某些屬性值,仍不能完整地復(fù)制到新的變量中。比如函數(shù)值,在深拷貝過程中,就會丟失。
問題
在實(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)該原封不動地傳入到 el-table 組件中,但是奇怪的事情在這里發(fā)生了,我們傳入的函數(shù)在組件中消失了!
問題分析
首先傳入 ak-table 的 row-key 屬性的值,它是一個(gè)函數(shù),即引用類型值,那么根據(jù)文章開頭所說,如果對引用類型的值進(jìn)行一般的深拷貝操作,是會丟失函數(shù)和數(shù)組等數(shù)據(jù)的。
在 ak-table 中,找到 row-key 屬性,因?yàn)闆]有在 props 中定義,所以應(yīng)該是保存在組件的 attrs 屬性中。去到 mounted 方法,在此打印attrs屬性中。去到mounted方法,在此打印attrs 的值,看看拷貝前后的數(shù)據(jù)對比。
控制臺輸出
———————————————————————————————————————
問題到這里就很清晰了,首先,ak-table 組件內(nèi)部其實(shí)是想對傳進(jìn)來的屬性值做初始化操作,然后就對 $attrs 進(jìn)行了深拷貝操作,拷貝之后就丟失了 row-key 屬性值,所以造成了數(shù)據(jù)丟失。
解決方案
對于傳入引用類型的值,直接通過子組件的 props 屬性接收來自父組件的值,然后不對傳進(jìn)來的值做處理,直接使用。
對于傳入引用類型的值,在拷貝時(shí)要‘特殊對待',把需要用到的屬性值遞歸拷貝到新的變量中。
總結(jié)
對于 JavaScript 中的基本類型和引用類型,以及對引用類型值拷貝的理解,是我們運(yùn)用這門語言進(jìn)行開發(fā)的基本技能。有時(shí)候常常因?yàn)榇中拇笠?,以為簡單粗暴的拷貝一個(gè)變量,就以為得到了它的完全復(fù)制體,因而造成了某些數(shù)據(jù)‘消失不見'的靈異事件。這時(shí)可以參考文章的解決方案,這是我在項(xiàng)目開發(fā)中遇到過的問題,以此記錄,希望對您有幫助。
到此這篇關(guān)于Vue組件傳值過程中丟失數(shù)據(jù)的分析與解決方案的文章就介紹到這了,更多相關(guān)Vue組件傳值丟失數(shù)據(jù)內(nèi)容請搜索腳本之家以前的文章或繼續(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)中國地圖省市縣下鉆功能
- vuex中遇到的坑,vuex數(shù)據(jù)改變,組件中頁面不渲染操作
- vue實(shí)現(xiàn)兩個(gè)組件之間數(shù)據(jù)共享和修改操作
- 淺析vue偵測數(shù)據(jù)的變化之基本實(shí)現(xiàn)
相關(guān)文章
vue2.0/3.0的響應(yīng)式原理及區(qū)別淺析
這篇文章主要給大家介紹了關(guān)于vue2.0/3.0響應(yīng)式原理及區(qū)別的相關(guān)資料,文中通過圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2021-05-05Vue的Eslint配置文件eslintrc.js說明與規(guī)則介紹
最近在跟著視頻敲項(xiàng)目時(shí),代碼提示出現(xiàn)很多奇奇怪怪的錯誤提示,百度了一下是eslintrc.js文件沒有配置相關(guān)命令,ESlint的語法檢測真的令人抓狂,現(xiàn)在總結(jié)一下這些命令的解釋2020-02-02uniapp 小程序和app map地圖上顯示多個(gè)酷炫動態(tài)的標(biāo)點(diǎn)效果(頭像后端傳過來)
這篇文章主要介紹了uniapp 小程序和app map地圖上顯示多個(gè)酷炫動態(tài)的標(biāo)點(diǎn)效果(頭像后端傳過來),本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-09-09vue和iview實(shí)現(xiàn)Scroll 數(shù)據(jù)無限滾動功能
今天小編就為大家分享一篇vue和iview實(shí)現(xiàn)Scroll 數(shù)據(jù)無限滾動功能,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10vue.js實(shí)現(xiàn)數(shù)據(jù)庫的JSON數(shù)據(jù)輸出渲染到html頁面功能示例
這篇文章主要介紹了vue.js實(shí)現(xiàn)數(shù)據(jù)庫的JSON數(shù)據(jù)輸出渲染到html頁面功能,結(jié)合實(shí)例形式分析了vue.js針對本地json數(shù)據(jù)的讀取、遍歷輸出相關(guān)操作技巧,需要的朋友可以參考下2019-08-08vue3中的reactive、readonly和shallowReactive使用詳解
在 Vue3 中,可以使用 shallowReactive 函數(shù)創(chuàng)建一個(gè)淺層響應(yīng)式對象,它接收一個(gè)普通對象作為參數(shù),返回一個(gè)淺層響應(yīng)式代理對象,本文給大家介紹vue3中的reactive、readonly和shallowReactive使用,感興趣的朋友跟隨小編一起看看吧2024-04-04