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

Vue中組件遞歸及使用問題

 更新時間:2022年03月07日 14:34:42   作者:程先生哈  
這篇文章主要介紹了Vue中組件的遞歸和使用問題,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下

  先來說下需求,就是一個表單,會有樹形結(jié)構(gòu)一樣,會有子表單,表單顯示什么內(nèi)容是后臺通過接口數(shù)據(jù)來確定的;這個時候就和樹形結(jié)構(gòu)一樣,肯定會有子組件的遞歸;這次是自己第一次寫遞歸,遇到了三個問題記錄下;

1、第一個問題就是,循環(huán)表單;看下圖

然后這里的數(shù)據(jù)返回的是這樣的:

說明下數(shù)據(jù)字段的含義:name屬性算是表頭,然后里面的valueType代表的是各種不同輸入框;比方說上面的7代表的是普通的下拉框,然后6就是普通的輸入框,1的話是布爾下拉框(其實在前端這邊1和7是一樣的,但是需要注意點的是Element中的下拉框判斷使用的是雙等于號,意思說,布爾true等于字符轉(zhuǎn)的false及true=='false'是正確的,所以這里需要格式化);如果等于的是8的話,代表這個是另一個子表單。如果有對應(yīng)的editData字段,并且這里還需要遞歸一次這樣的數(shù)據(jù);

來看下我的格式化數(shù)據(jù)的過程:

formatterData(editDataAjax, id) {
      editDataAjax.map(item => {
        // 如果是類型8,則需要再次展開數(shù)據(jù)
        if (item.valueType == 8) {
          item.editData = [];
          item.expanded = false;
        }
        //  如果是枚舉的類型或者布爾的類型,則需要給他格式化數(shù)據(jù)一下,用來創(chuàng)建option
        if (item.valueType == 7 || item.valueType == 1) {
          item.option = [];
          for (const key in item.data) {
            if (item.data.hasOwnProperty(key)) {
              const element = item.data[key];
              if (item.valueType == 1) {
                // 如果是布爾類型的話,改成布爾
                item.option.push({
                  value: key === "true" ? true : false,
                  label: element
                });
              } else {
                item.option.push({
                  value: key,
                  label: element
                });
              }
            }
          }
        }
      });
}

最后這里需要注意的一點就是,循環(huán)創(chuàng)建輸入框和下拉框的話,需要使用v-model的格式,如果單純的時候的是:value模式綁定的話,會有問題,需要格外的注意,請看下面的代碼

<template v-if="item.valueType==6">
       <div class="inputDom">
          <el-input v-model="item['value']" :disabled="item.flag==1?true:false"></el-input>
       </div>
 </template>

2、遞歸組件的使用

  首先要說下遞歸組件怎么使用,就是我的組件文件名叫做fromItem.vue;然后我的name名稱也是fromItem(一定要有name),組件遞歸使用其實和使用其他的組件是一樣的;需要先引入

import fromItem from './fromItem';

然后注冊

 components: {
    fromItem
   },

使用的時候,也是一樣的

<div class="childDom">
         <fromItem :editData="item.editData" />
 </div>

但是這個時候,我們的數(shù)據(jù)就要發(fā)生相對應(yīng)的變化:

當(dāng)我們給父級的editData賦值的時候,就會出來第一層級,讓我們給父級中任意一個editData賦值,就會出現(xiàn)子組件遞歸了。這個時候不管有幾層,都會出現(xiàn)相對應(yīng)的表單了;

3、關(guān)于數(shù)據(jù)的整理和構(gòu)建

  開始的時候,我把每次請求的數(shù)據(jù)函數(shù)都放在了子組件中進(jìn)行,就是fromItem.vue文件中進(jìn)行,但是這樣的話,每次請求到最新的數(shù)據(jù),如果我不保存上次的數(shù)據(jù)的話,發(fā)現(xiàn)就沒有父表單了,只能出現(xiàn)子表單;如果要是保存的話,我就需要每次請求完成之后,調(diào)用父組件的方法,保存很多數(shù)據(jù)。造成了理解的困難;

  所以現(xiàn)在使用的方式就是,子組件文件,也就是fromItem.vue組件,不做任何數(shù)據(jù)的處理,只是接受并且展示數(shù)據(jù);數(shù)據(jù)的請求,整理,和最后的編輯保存都在父組件中完成,這樣的話,就不會造成數(shù)據(jù)的混亂,畢竟遞歸的時候,做的越多越容易出錯;

到此這篇關(guān)于Vue中組件的遞歸的文章就介紹到這了,更多相關(guān)vue組件遞歸內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue3.0 CLI - 2.1 -  component 組件入門教程

    vue3.0 CLI - 2.1 - component 組件入門教程

    這篇文章主要介紹了vue3.0 CLI - 2.1 - component 組件入門教程,本文主要的關(guān)注點就是組件,本文通過實例代碼相結(jié)合的形式給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2018-09-09
  • 前端token中4個存儲位置的優(yōu)缺點說明

    前端token中4個存儲位置的優(yōu)缺點說明

    這篇文章主要介紹了前端token中4個存儲位置的優(yōu)缺點說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-10-10
  • element-ui中實現(xiàn)tree子節(jié)點部分選中時父節(jié)點也選中

    element-ui中實現(xiàn)tree子節(jié)點部分選中時父節(jié)點也選中

    這篇文章主要介紹了element-ui中實現(xiàn)tree子節(jié)點部分選中時父節(jié)點也選中的方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • vue3解決跨域問題詳細(xì)代碼親測有效

    vue3解決跨域問題詳細(xì)代碼親測有效

    跨域,跨的是不同域,也就是協(xié)議或主機或或端口號不同造成的現(xiàn)象,本文給大家分享vue3解決跨域問題詳細(xì)代碼親測有效,感興趣的朋友跟隨小編一起看看吧
    2022-11-11
  • vue實現(xiàn)移動端懸浮窗效果

    vue實現(xiàn)移動端懸浮窗效果

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)移動端懸浮窗效果,vuejs實現(xiàn)div拖拽移動,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-12-12
  • vue3中g(shù)etCurrentInstance獲取組件實例踩坑詳細(xì)記錄

    vue3中g(shù)etCurrentInstance獲取組件實例踩坑詳細(xì)記錄

    getCurrentInstance()是Vue.js3?Composition?API中的一個函數(shù),它的作用是獲取當(dāng)前組件的實例對象,下面這篇文章主要給大家介紹了關(guān)于vue3中g(shù)etCurrentInstance獲取組件踩坑的相關(guān)資料,需要的朋友可以參考下
    2024-02-02
  • vant框架van-cell插槽無法換行問題及解決

    vant框架van-cell插槽無法換行問題及解決

    這篇文章主要介紹了vant框架van-cell插槽無法換行問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-01-01
  • Vue批量圖片顯示時遇到的路徑被解析問題

    Vue批量圖片顯示時遇到的路徑被解析問題

    這篇文章主要介紹了Vue批量圖片顯示時遇到的路徑被解析問題,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • Vue + Elementui實現(xiàn)多標(biāo)簽頁共存的方法

    Vue + Elementui實現(xiàn)多標(biāo)簽頁共存的方法

    這篇文章主要介紹了Vue + Elementui實現(xiàn)多標(biāo)簽頁共存的方法,本文通過實例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-06-06
  • 解析VUE中nextTick是什么

    解析VUE中nextTick是什么

    nextTick是Vue提供的一個全局API,由于Vue的異步更新策略導(dǎo)致我們對數(shù)據(jù)的修改不會立刻體現(xiàn),在DOM變化上,此時如果想要立即獲取更新后的DOM狀態(tài),就需要使用這個方法,這篇文章主要介紹了解析VUE中nextTick,需要的朋友可以參考下
    2022-11-11

最新評論