中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Vue組件傳值過程中丟失數據怎么辦

發布時間:2021-03-17 14:14:43 來源:億速云 閱讀:347 作者:小新 欄目:開發技術

這篇文章將為大家詳細講解有關Vue組件傳值過程中丟失數據怎么辦,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

問題

在實際項目中,假如使用了二次封裝的組件,并且封裝的組件內部做了一些屬性值的深拷貝操作,就有極有可能因為傳入的屬性值是引用類型的值,導致丟失部分數據。

舉例

以基于 el-table 封裝的 ak-table 組件為例:

往 ak-table 組件中傳入 row-key 屬性,該屬性可傳入一個函數:Function(row),具體見官方文檔。

Vue組件傳值過程中丟失數據怎么辦

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

Vue組件傳值過程中丟失數據怎么辦

問題分析

首先傳入 ak-table 的 row-key 屬性的值,它是一個函數,即引用類型值,那么根據文章開頭所說,如果對引用類型的值進行一般的深拷貝操作,是會丟失函數和數組等數據的。

在 ak-table 中,找到 row-key 屬性,因為沒有在 props 中定義,所以應該是保存在組件的 attrs 屬性中。去到 mounted 方法,在此打印attrs屬性中。去到mounted方法,在此打印attrs 的值,看看拷貝前后的數據對比。

Vue組件傳值過程中丟失數據怎么辦

控制臺輸出

———————————————————————————————————————

Vue組件傳值過程中丟失數據怎么辦

問題到這里就很清晰了,首先,ak-table 組件內部其實是想對傳進來的屬性值做初始化操作,然后就對 $attrs 進行了深拷貝操作,拷貝之后就丟失了 row-key 屬性值,所以造成了數據丟失。

解決方案

對于傳入引用類型的值,直接通過子組件的 props 屬性接收來自父組件的值,然后不對傳進來的值做處理,直接使用。

對于傳入引用類型的值,在拷貝時要‘特殊對待',把需要用到的屬性值遞歸拷貝到新的變量中。

關于“Vue組件傳值過程中丟失數據怎么辦”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

vue
AI

鹿邑县| 台安县| 龙川县| 哈尔滨市| 广丰县| 洪泽县| 诏安县| 宜都市| 海门市| 文昌市| 恭城| 嵊泗县| 永平县| 当阳市| 师宗县| 拜泉县| 舞阳县| 娄底市| 田东县| 甘肃省| 奈曼旗| 柳河县| 时尚| 隆林| 靖远县| 三穗县| 夹江县| 宜都市| 永和县| 乌兰县| 耒阳市| 尤溪县| 晋城| 延长县| 金溪县| 阿拉善左旗| 澄城县| 广灵县| 宾阳县| 平凉市| 常山县|