91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

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

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

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

花莲县| 双鸭山市| 五原县| 鲁甸县| 名山县| 仁化县| 大姚县| 云霄县| 抚宁县| 驻马店市| 清水河县| 奉节县| 右玉县| 武宁县| 望谟县| 商河县| 荥经县| 沾益县| 安西县| 余干县| 鄱阳县| 方正县| 怀宁县| 白山市| 溧水县| 义乌市| 木兰县| 芒康县| 沅陵县| 永安市| 霸州市| 沙洋县| 翼城县| 乐至县| 沧州市| 尼玛县| 淳安县| 南木林县| 伊春市| 城口县| 香港|