Vue中組件遞歸及使用問題
先來說下需求,就是一個表單,會有樹形結構一樣,會有子表單,表單顯示什么內容是后臺通過接口數據來確定的;這個時候就和樹形結構一樣,肯定會有子組件的遞歸;這次是自己第一次寫遞歸,遇到了三個問題記錄下;
1、第一個問題就是,循環(huán)表單;看下圖
然后這里的數據返回的是這樣的:
說明下數據字段的含義:name屬性算是表頭,然后里面的valueType代表的是各種不同輸入框;比方說上面的7代表的是普通的下拉框,然后6就是普通的輸入框,1的話是布爾下拉框(其實在前端這邊1和7是一樣的,但是需要注意點的是Element中的下拉框判斷使用的是雙等于號,意思說,布爾true等于字符轉的false及true=='false'是正確的,所以這里需要格式化);如果等于的是8的話,代表這個是另一個子表單。如果有對應的editData字段,并且這里還需要遞歸一次這樣的數據;
來看下我的格式化數據的過程:
formatterData(editDataAjax, id) { editDataAjax.map(item => { // 如果是類型8,則需要再次展開數據 if (item.valueType == 8) { item.editData = []; item.expanded = false; } // 如果是枚舉的類型或者布爾的類型,則需要給他格式化數據一下,用來創(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>
但是這個時候,我們的數據就要發(fā)生相對應的變化:
當我們給父級的editData賦值的時候,就會出來第一層級,讓我們給父級中任意一個editData賦值,就會出現子組件遞歸了。這個時候不管有幾層,都會出現相對應的表單了;
3、關于數據的整理和構建
開始的時候,我把每次請求的數據函數都放在了子組件中進行,就是fromItem.vue文件中進行,但是這樣的話,每次請求到最新的數據,如果我不保存上次的數據的話,發(fā)現就沒有父表單了,只能出現子表單;如果要是保存的話,我就需要每次請求完成之后,調用父組件的方法,保存很多數據。造成了理解的困難;
所以現在使用的方式就是,子組件文件,也就是fromItem.vue組件,不做任何數據的處理,只是接受并且展示數據;數據的請求,整理,和最后的編輯保存都在父組件中完成,這樣的話,就不會造成數據的混亂,畢竟遞歸的時候,做的越多越容易出錯;
到此這篇關于Vue中組件的遞歸的文章就介紹到這了,更多相關vue組件遞歸內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vue3.0 CLI - 2.1 - component 組件入門教程
這篇文章主要介紹了vue3.0 CLI - 2.1 - component 組件入門教程,本文主要的關注點就是組件,本文通過實例代碼相結合的形式給大家介紹的非常詳細,需要的朋友可以參考下2018-09-09element-ui中實現tree子節(jié)點部分選中時父節(jié)點也選中
這篇文章主要介紹了element-ui中實現tree子節(jié)點部分選中時父節(jié)點也選中的方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08vue3中getCurrentInstance獲取組件實例踩坑詳細記錄
getCurrentInstance()是Vue.js3?Composition?API中的一個函數,它的作用是獲取當前組件的實例對象,下面這篇文章主要給大家介紹了關于vue3中getCurrentInstance獲取組件踩坑的相關資料,需要的朋友可以參考下2024-02-02