国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

vue element動態(tài)渲染、移除表單并添加驗證的實現(xiàn)

2024-05-06 15:43:12
字體:
供稿:網(wǎng)友

又接到新需求了吧~~

背景

在一個大表單里,有可能會出現(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)表單怎么填寫對應的 prop ...

好吧,我當時也思考了一會,最后選擇數(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ù)點擊的當前 index 移除對象數(shù)組的元素   this.form['azList'].splice(index, 1)  },  goBack() {   window.history.back(-1)  } }}

請格外注意動態(tài)添加表單的 rule 和 prop

每個動態(tài)添加的表單都要加上 rule

prop 需要根據(jù)對象數(shù)組下標綁定設(shè)置對應的 value(:prop="'azList' + index + '.azName'")

那么對應的 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>            
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 库尔勒市| 东源县| 浙江省| 大连市| 平陆县| 乌恰县| 东阳市| 宜君县| 宾阳县| 广水市| 佳木斯市| 滦南县| 临高县| 抚宁县| 彩票| 涡阳县| 德江县| 刚察县| 和政县| 拜泉县| 大连市| 横山县| 华亭县| 青神县| 彭山县| 温州市| 台北市| 甘孜县| 新源县| 铜川市| 韶山市| 苏尼特右旗| 开封市| 临泽县| 墨江| 固阳县| 麻阳| 教育| 鄂托克前旗| 渝北区| 湖南省|