Element實(shí)現(xiàn)動(dòng)態(tài)增加多個(gè)輸入框并校驗(yàn)
前言
在做復(fù)雜的動(dòng)態(tài)表單,實(shí)現(xiàn)業(yè)務(wù)動(dòng)態(tài)變動(dòng),比如有一條需要?jiǎng)討B(tài)添加的el-form-item中包含了多個(gè)輸入框,并實(shí)現(xiàn)表單驗(yàn)證,但在element-ui組件庫(kù)中給出的表單校驗(yàn)中沒(méi)有這樣的格式,想要實(shí)現(xiàn)這個(gè)功能就來(lái)跟我一起學(xué)習(xí)吧。
實(shí)現(xiàn)通過(guò)按鈕動(dòng)態(tài)增加表單并驗(yàn)證必填
先上實(shí)現(xiàn)效果圖:
實(shí)現(xiàn)代碼如下:
<el-form-item v-for="(item, index) in form.settings" :key="index" :label="'設(shè)置' + (index + 1)"> <el-form-item label="名稱" :prop="'settings.'+index+'.name'" :rules="[{ required: true, message: '必填項(xiàng)', trigger: 'change' }]" label-width="50px"> <el-input v-model.trim="item.name" style="width: 100px" /> </el-form-item> <el-form-item label="值" :prop="'settings.'+index+'.val'" :rules="[{ required: true, message: '必填項(xiàng)', trigger: 'change' }]" label-width="50px"> <el-input v-model.trim="item.val" style="width: 100px" /> </el-form-item> <el-form-item label="key" :prop="'settings.'+index+'.key'" :rules="[{ required: true, message: '必填項(xiàng)', trigger: 'change' }]" label-width="50px"> <el-input v-model.trim="item.key" style="width: 100px" /> </el-form-item> <el-form-item> <el-button @click.prevent="removeSetting(item)">刪除</el-button> </el-form-item> </el-form-item> <el-form-item label=" "> <el-button icon="el-icon-circle-plus-outline" @click="addSetting()">新增設(shè)置</el-button> </el-form-item>
實(shí)現(xiàn)思路
在 el-form-item
中嵌套 el-form-item
,只需要拼接一下prop就可以直接使用校驗(yàn):
:prop=“‘settings.’+index+‘.name’”
- settings 是for循環(huán)取值的數(shù)組
- name 是輸入框雙向綁定的值
:rules=“[{ required: true, message: ‘必填項(xiàng)’, trigger: ‘change’ }]”
- 校驗(yàn)規(guī)則中需要校驗(yàn)的數(shù)組
加入以下方法可動(dòng)態(tài)增刪表單:
removeSetting(item) { var index = this.form.settings.indexOf(item) if (index !== -1) { this.form.settings.splice(index, 1) } }, addSetting() { this.form.settings.push({ 'name': '', 'key': '', 'val': '' }) },
實(shí)現(xiàn)動(dòng)態(tài)多個(gè)輸入框?yàn)樾袃?nèi)模式,其它為行外模式
效果如圖:
實(shí)現(xiàn)思路
在 el-form
定義 :inline="true"
實(shí)現(xiàn)行內(nèi)模式,以便于動(dòng)態(tài)增加的多個(gè)輸入框在同一行顯示;再通過(guò) Layout 布局
將其它比較小的單個(gè)輸入框控制在一個(gè)行內(nèi),通過(guò) row 和 col 組件,并通過(guò) col 組件的 span 屬性我們就可以自由地組合布局。
實(shí)現(xiàn)代碼如下:
<el-form ref="form" :inline="true" :model="form" :rules="rules" size="small" label-width="120px"> <el-row> <el-col :span="24"> <el-form-item label="test1" prop="teest1"> <el-input v-model.trim="form.test1" style="width: 220px" /> </el-form-item> </el-col> <el-col :span="24"> <el-form-item label="test2" prop="test2"> <el-input v-model.trim="form.test2" style="width: 220px" /> </el-form-item> </el-col> <el-col :span="24"> <el-form-item label="test3" prop="test3"> <el-input v-model.trim="form.test3" style="width: 220px" /> </el-form-item> </el-col> <el-col :span="24"> <el-form-item v-for="(item, index) in form.settings" :key="index" :label="'設(shè)置' + (index + 1)"> <el-form-item label="名稱" :prop="'settings.'+index+'.name'" :rules="[{ required: true, message: '必填項(xiàng)', trigger: 'change' }]" label-width="50px"> <el-input v-model.trim="item.name" style="width: 100px" /> </el-form-item> <el-form-item label="值" :prop="'settings.'+index+'.val'" :rules="[{ required: true, message: '必填項(xiàng)', trigger: 'change' }]" label-width="50px"> <el-input v-model.trim="item.val" style="width: 100px" /> </el-form-item> <el-form-item label="key" :prop="'settings.'+index+'.key'" :rules="[{ required: true, message: '必填項(xiàng)', trigger: 'change' }]" label-width="50px"> <el-input v-model.trim="item.key" style="width: 100px" /> </el-form-item> <el-form-item> <el-button @click.prevent="removeSetting(item)">刪除</el-button> </el-form-item> </el-form-item> </el-col> <el-col :span="24"> <el-form-item label=" "> <el-button icon="el-icon-circle-plus-outline" @click="addSetting()">新增設(shè)置</el-button> </el-form-item> </el-col> </el-row> </el-form>
到此這篇關(guān)于Element實(shí)現(xiàn)動(dòng)態(tài)增加多個(gè)輸入框并校驗(yàn)的文章就介紹到這了,更多相關(guān)Element動(dòng)態(tài)增加輸入框并校驗(yàn)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
在vue中給后臺(tái)接口傳的值為數(shù)組的格式代碼
這篇文章主要介紹了在vue中給后臺(tái)接口傳的值為數(shù)組的格式代碼,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11vue實(shí)現(xiàn)一個(gè)懶加載的樹(shù)狀表格實(shí)例
這篇文章主要介紹了vue實(shí)現(xiàn)一個(gè)懶加載的樹(shù)狀表格實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-05-05vue中,在本地緩存中讀寫(xiě)數(shù)據(jù)的方法
今天小編就為大家分享一篇vue中,在本地緩存中讀寫(xiě)數(shù)據(jù)的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-09-09ant-design-vue中的table自定義格式渲染解析
這篇文章主要介紹了ant-design-vue中的table自定義格式渲染,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-10-10