vue element動態(tài)渲染、移除表單并添加驗證的實現(xiàn)
又接到新需求了吧~~
背景
在一個大表單里,有可能會出現(xiàn)這種需求,用戶可以自己操作動態(tài)添加、移除表單,更加個性化的效果。
常見于填寫個人信息、附加內(nèi)容的表單
例如:
“工作經(jīng)歷”可以用戶自己點擊繼續(xù)添加按鈕,在原有的表單后面 append 多一個表單,不需要就點擊右上方 X 按鈕移除
問題
在實現(xiàn)之前,提出幾個問題
- vue 怎么動態(tài)渲染或移除表單上去
- v-model 怎么綁定動態(tài)添加表單的 value 值
- 動態(tài)新增的表單如何驗證
- 動態(tài)表單怎么填寫對應(yīng)的 prop
- ...
好吧,我當(dāng)時也思考了一會,最后選擇數(shù)組方式,動態(tài)渲染
代碼實現(xiàn)講解
利用數(shù)組,v-for 循環(huán)方式,可以完美實現(xiàn)動態(tài)渲染和移除,因為操作的只有對象數(shù)組而已
export default { name: 'vouchersDetail', data() { return { form: { regionName: '', regionCode: '', // 動態(tài)添加的對象數(shù)組 azList: [ { azName: '', logicCode: '', physicCode: '' } ] } } }, computed: { // 至少保留一個動態(tài)表單的開關(guān) isShowCloseBtn() { return this.form['azList'].length > 1 } }, methods: { addItem() { // 點擊添加表單的按鈕,只需要將表單綁定的 value 作為對象 push 到對象數(shù)組 this.form['azList'].push({ azName: '', logicCode: '', physicCode: '', weight: '' }) }, deleteItem(index) { // 點擊移除表單的按鈕,根據(jù)點擊的當(dāng)前 index 移除對象數(shù)組的元素 this.form['azList'].splice(index, 1) }, goBack() { window.history.back(-1) } } }
請格外注意動態(tài)添加表單的 rule 和 prop
每個動態(tài)添加的表單都要加上 rule
prop 需要根據(jù)對象數(shù)組下標(biāo)綁定設(shè)置對應(yīng)的 value(:prop="'azList' + index + '.azName'")
那么對應(yīng)的 html 形式為
<div class="section-form" v-for="(item, index) in form.azList" :key="index"> <span v-if="isShowCloseBtn" class="close" @click="deleteItem(index)"> <i class="el-icon-close"></i> </span> <el-form-item label="可用區(qū)名稱:" :rules="[{ required: true, message: '可用區(qū)名稱不能為空' }]" :prop="'azList[' + index + '].azName'" label-width="150px"> <el-input placeholder="請輸入可用區(qū)名稱" v-model="item.azName" :maxlength="30"></el-input> </el-form-item> <el-form-item label="邏輯可用區(qū)編碼:" :rules="[{ required: true, message: '邏輯可用區(qū)編碼不能為空' }]" label-width="150px" :prop="'azList[' + index + '].logicCode'"> <el-input placeholder="請輸入唯一ID" v-model="item.logicCode" :maxlength="30"></el-input> </el-form-item> <el-form-item label="物理可用區(qū)編碼:" :rules="[{ required: true, message: '物理可用區(qū)編碼不能為空' }]" label-width="150px" :prop="'azList[' + index + '].physicCode'"> <el-input placeholder="請輸入唯一ID" v-model="item.physicCode" :maxlength="30"></el-input> </el-form-item> </div>
寫在后面
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- element-plus+Vue3實現(xiàn)表格數(shù)據(jù)動態(tài)渲染
- element-plus日歷(Calendar)動態(tài)渲染以及避坑指南
- vue+elementUI組件遞歸實現(xiàn)可折疊動態(tài)渲染多級側(cè)邊欄導(dǎo)航
- vue element 中的table動態(tài)渲染實現(xiàn)(動態(tài)表頭)
- 詳解VUE Element-UI多級菜單動態(tài)渲染的組件
- VUE2.0+ElementUI2.0表格el-table循環(huán)動態(tài)列渲染的寫法詳解
- Vue+ElementUI實現(xiàn)表單動態(tài)渲染、可視化配置的方法
- Element-Plus實現(xiàn)動態(tài)渲染圖標(biāo)的示例代碼
相關(guān)文章
vue - vue.config.js中devServer配置方式
今天小編就為大家分享一篇vue - vue.config.js中devServer配置方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-10-10Vue中Router路由兩種模式hash與history詳解
這篇文章主要介紹了Vue中Router路由的兩種模式,分別對hash模式與history模式作了簡要分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助2021-09-09區(qū)分vue-router的hash和history模式
這篇文章主要介紹了區(qū)分vue-router的hash和history模式,幫助大家更好的理解和學(xué)習(xí)vue路由,感興趣的朋友可以了解下2020-10-10使用vue編寫h5公眾號跳轉(zhuǎn)小程序的實現(xiàn)代碼
這篇文章主要介紹了使用vue編寫h5公眾號跳轉(zhuǎn)小程序,本文通過實例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11