国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務(wù)器之家 - 編程語言 - JavaScript - vue.js - Vue組件傳值過程中丟失數(shù)據(jù)的分析與解決方案

Vue組件傳值過程中丟失數(shù)據(jù)的分析與解決方案

2022-02-19 17:30Chieffo vue.js

這篇文章主要給大家介紹了關(guān)于Vue組件傳值過程中丟失數(shù)據(jù)的分析與解決方案,文中通過圖文介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

在上一篇文章 JavaScript 中的兩種數(shù)據(jù)類型中,分別介紹了基本類型和引用類型,以及引用類型的淺拷貝與深拷貝。這里需要注意的是,該文章中深拷貝引用類型值的方法,并不是完美的,引用類型值中的某些屬性值,仍不能完整地復(fù)制到新的變量中。比如函數(shù)值,在深拷貝過程中,就會丟失。

問題

在實際項目中,假如使用了二次封裝的組件,并且封裝的組件內(nèi)部做了一些屬性值的深拷貝操作,就有極有可能因為傳入的屬性值是引用類型的值,導(dǎo)致丟失部分?jǐn)?shù)據(jù)。

舉例

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

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

Vue組件傳值過程中丟失數(shù)據(jù)的分析與解決方案

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

Vue組件傳值過程中丟失數(shù)據(jù)的分析與解決方案

問題分析

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

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

Vue組件傳值過程中丟失數(shù)據(jù)的分析與解決方案

控制臺輸出

―――――――――――――――――――――――――――――――――――――――

Vue組件傳值過程中丟失數(shù)據(jù)的分析與解決方案

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

解決方案

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

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

總結(jié)

對于 JavaScript 中的基本類型和引用類型,以及對引用類型值拷貝的理解,是我們運(yùn)用這門語言進(jìn)行開發(fā)的基本技能。有時候常常因為粗心大意,以為簡單粗暴的拷貝一個變量,就以為得到了它的完全復(fù)制體,因而造成了某些數(shù)據(jù)‘消失不見"的靈異事件。這時可以參考文章的解決方案,這是我在項目開發(fā)中遇到過的問題,以此記錄,希望對您有幫助。

到此這篇關(guān)于Vue組件傳值過程中丟失數(shù)據(jù)的分析與解決方案的文章就介紹到這了,更多相關(guān)Vue組件傳值丟失數(shù)據(jù)內(nèi)容請搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!

參考鏈接:JavaScript深拷貝的一些坑

原文鏈接:https://segmentfault.com/a/1190000039415844

延伸 · 閱讀

精彩推薦
  • vue.jsVue項目中實現(xiàn)帶參跳轉(zhuǎn)功能

    Vue項目中實現(xiàn)帶參跳轉(zhuǎn)功能

    最近做了一個手機(jī)端系統(tǒng),其中遇到了父頁面需要攜帶參數(shù)跳轉(zhuǎn)至子頁面的問題,現(xiàn)已解決,下面分享一下實現(xiàn)過程,感興趣的朋友一起看看吧...

    YiluRen丶4302022-03-03
  • vue.jsVue中引入svg圖標(biāo)的兩種方式

    Vue中引入svg圖標(biāo)的兩種方式

    這篇文章主要給大家介紹了關(guān)于Vue中引入svg圖標(biāo)的兩種方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的...

    十里不故夢10222021-12-31
  • vue.jsVue多選列表組件深入詳解

    Vue多選列表組件深入詳解

    這篇文章主要介紹了Vue多選列表組件深入詳解,這個是vue的基本組件,有需要的同學(xué)可以研究下...

    yukiwu6752022-01-25
  • vue.jsVue2.x 項目性能優(yōu)化之代碼優(yōu)化的實現(xiàn)

    Vue2.x 項目性能優(yōu)化之代碼優(yōu)化的實現(xiàn)

    這篇文章主要介紹了Vue2.x 項目性能優(yōu)化之代碼優(yōu)化的實現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋...

    優(yōu)小U9632022-02-21
  • vue.js梳理一下vue中的生命周期

    梳理一下vue中的生命周期

    看過很多人講vue的生命周期,但總是被繞的云里霧里,尤其是自學(xué)的同學(xué),可能js的基礎(chǔ)也不是太牢固,聽起來更是吃力,那我就已個人之淺見,以大白話...

    CRMEB技術(shù)團(tuán)隊7992021-12-22
  • vue.js詳解vue 表單綁定與組件

    詳解vue 表單綁定與組件

    這篇文章主要介紹了vue 表單綁定與組件的相關(guān)資料,幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下...

    Latteitcjz6432022-02-12
  • vue.js用vite搭建vue3應(yīng)用的實現(xiàn)方法

    用vite搭建vue3應(yīng)用的實現(xiàn)方法

    這篇文章主要介紹了用vite搭建vue3應(yīng)用的實現(xiàn)方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下...

    Asiter7912022-01-22
  • vue.jsVue2.x-使用防抖以及節(jié)流的示例

    Vue2.x-使用防抖以及節(jié)流的示例

    這篇文章主要介紹了Vue2.x-使用防抖以及節(jié)流的示例,幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下...

    Kyara6372022-01-25
主站蜘蛛池模板: 婷婷成人av| 中文字幕一区二区三区久久 | 欧美亚洲天堂 | 亚洲成人精品一区 | 国产欧美日韩二区 | 国内成人免费视频 | 亚洲精品视频网 | 成年人在线观看 | 国产精品一二三区 | 欧美色欧美亚洲另类七区 | 国产资源在线播放 | 国产精品一区久久久 | 日韩视频一区二区三区 | 九九只有精品 | 色综合久| 亚洲一区在线免费观看 | 岛国av免费 | 亚洲男人天堂网 | 在线天堂v | 亚洲 成人 av| 偷拍自拍亚洲欧美 | 最新中文字幕在线 | 欧美福利在线观看 | 成人av网站在线观看 | 中文字幕一区二区三区日韩精品 | 欧美日韩精品一区二区三区蜜桃 | 国产精品精 | 国产一区二区欧美 | 久草一区 | 密桃在线视频 | 久久人体视频 | 欧美日韩国产在线播放 | 国内精品久久久 | 爱操在线| 在线视频一区二区 | 91精品国产综合久久久久久丝袜 | 国内外精品一区二区三区 | 久久久久久综合 | 久久久久久国产精品 | 综合九九| 秋霞精品 |