亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

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

扶风县| 黎平县| 万山特区| 兴业县| 横峰县| 信宜市| 滦平县| 澜沧| 定安县| 阿勒泰市| 民权县| 密山市| 桦甸市| 和田县| 鄯善县| 泗阳县| 诸城市| 寿宁县| 碌曲县| 大洼县| 万载县| 漯河市| 栾城县| 喜德县| 克拉玛依市| 滨海县| 辽中县| 两当县| 聂荣县| 庆元县| 长沙县| 金寨县| 虎林市| 方正县| 安化县| 伊吾县| 谢通门县| 会昌县| 米泉市| 黄山市| 盈江县|