欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

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

前言

在上一篇文章 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深拷貝的一些坑

相關(guān)文章

  • vue cli升級webapck4總結(jié)

    vue cli升級webapck4總結(jié)

    這篇文章主要介紹了vue cli升級webapck4的步驟以及需要注意的地方,大家可以跟著操作學(xué)習(xí)下。
    2018-04-04
  • vue2.0/3.0的響應(yīng)式原理及區(qū)別淺析

    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-05
  • vue的keep-alive用法技巧

    vue的keep-alive用法技巧

    在本篇文章里小編給大家整理的是關(guān)于vue的keep-alive用法技巧以及實(shí)例代碼,需要的朋友們學(xué)習(xí)下。
    2019-08-08
  • Vue的Eslint配置文件eslintrc.js說明與規(guī)則介紹

    Vue的Eslint配置文件eslintrc.js說明與規(guī)則介紹

    最近在跟著視頻敲項(xiàng)目時(shí),代碼提示出現(xiàn)很多奇奇怪怪的錯誤提示,百度了一下是eslintrc.js文件沒有配置相關(guān)命令,ESlint的語法檢測真的令人抓狂,現(xiàn)在總結(jié)一下這些命令的解釋
    2020-02-02
  • uniapp 小程序和app map地圖上顯示多個(gè)酷炫動態(tài)的標(biāo)點(diǎn)效果(頭像后端傳過來)

    uniapp 小程序和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-09
  • vue和iview實(shí)現(xiàn)Scroll 數(shù)據(jù)無限滾動功能

    vue和iview實(shí)現(xiàn)Scroll 數(shù)據(jù)無限滾動功能

    今天小編就為大家分享一篇vue和iview實(shí)現(xiàn)Scroll 數(shù)據(jù)無限滾動功能,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • vue+iview分頁組件的封裝

    vue+iview分頁組件的封裝

    這篇文章主要為大家詳細(xì)介紹了vue+iview分頁組件的封裝,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-11-11
  • Vue操作數(shù)組的幾種常用方法小結(jié)

    Vue操作數(shù)組的幾種常用方法小結(jié)

    本文主要介紹了Vue操作數(shù)組的幾種常用方法小結(jié),主要包括map、filter、forEach、find 和 findIndex 、some 和 every、includes、Array.from這幾種方法,感興趣的可以了解一下
    2023-09-09
  • vue.js實(shí)現(xiàn)數(shù)據(jù)庫的JSON數(shù)據(jù)輸出渲染到html頁面功能示例

    vue.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-08
  • vue3中的reactive、readonly和shallowReactive使用詳解

    vue3中的reactive、readonly和shallowReactive使用詳解

    在 Vue3 中,可以使用 shallowReactive 函數(shù)創(chuàng)建一個(gè)淺層響應(yīng)式對象,它接收一個(gè)普通對象作為參數(shù),返回一個(gè)淺層響應(yīng)式代理對象,本文給大家介紹vue3中的reactive、readonly和shallowReactive使用,感興趣的朋友跟隨小編一起看看吧
    2024-04-04

最新評論