中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

vue element動態渲染、移除表單并添加驗證的實現

發布時間:2020-09-27 11:19:55 來源:腳本之家 閱讀:438 作者:筱月 欄目:web開發

又接到新需求了吧~~

背景

在一個大表單里,有可能會出現這種需求,用戶可以自己操作動態添加、移除表單,更加個性化的效果。

常見于填寫個人信息、附加內容的表單

例如:

“工作經歷”可以用戶自己點擊繼續添加按鈕,在原有的表單后面 append 多一個表單,不需要就點擊右上方 X 按鈕移除

問題

在實現之前,提出幾個問題

  • vue 怎么動態渲染或移除表單上去
  • v-model 怎么綁定動態添加表單的 value 值
  • 動態新增的表單如何驗證
  • 動態表單怎么填寫對應的 prop
  • ...

好吧,我當時也思考了一會,最后選擇數組方式,動態渲染

代碼實現講解

利用數組,v-for 循環方式,可以完美實現動態渲染和移除,因為操作的只有對象數組而已

export default {
 name: 'vouchersDetail',
 data() {
  return {
   form: {
    regionName: '',
    regionCode: '',
  // 動態添加的對象數組
    azList: [
     {
      azName: '',
      logicCode: '',
      physicCode: ''
     }
    ]
   }
  }
 },
 computed: {
  // 至少保留一個動態表單的開關
  isShowCloseBtn() {
   return this.form['azList'].length > 1
  }
 },
 methods: {
  addItem() {
   // 點擊添加表單的按鈕,只需要將表單綁定的 value 作為對象 push 到對象數組
   this.form['azList'].push({
    azName: '',
    logicCode: '',
    physicCode: '',
    weight: ''
   })
  },
  deleteItem(index) {
   // 點擊移除表單的按鈕,根據點擊的當前 index 移除對象數組的元素
   this.form['azList'].splice(index, 1)
  },
  goBack() {
   window.history.back(-1)
  }
 }
}

請格外注意動態添加表單的 rule 和 prop

每個動態添加的表單都要加上 rule

prop 需要根據對象數組下標綁定設置對應的 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="可用區名稱:"
  :rules="[{ required: true, message: '可用區名稱不能為空' }]"
  :prop="'azList[' + index + '].azName'"
  label-width="150px"> 
  <el-input placeholder="請輸入可用區名稱" v-model="item.azName" :maxlength="30"></el-input> 
 </el-form-item> 
 <el-form-item label="邏輯可用區編碼:"
  :rules="[{ required: true, message: '邏輯可用區編碼不能為空' }]"
  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="物理可用區編碼:"
  :rules="[{ required: true, message: '物理可用區編碼不能為空' }]"
  label-width="150px"
  :prop="'azList[' + index + '].physicCode'"> 
  <el-input placeholder="請輸入唯一ID" v-model="item.physicCode" :maxlength="30"></el-input> 
 </el-form-item>
</div>

寫在后面

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

东乡族自治县| 公安县| 论坛| 临颍县| 磐石市| 额敏县| 鹤庆县| 芷江| 揭西县| 延寿县| 永昌县| 临沭县| 司法| 太原市| 界首市| 仁寿县| 阜康市| 巴彦县| 湖北省| 夹江县| 永福县| 凤山县| 夏邑县| 鄱阳县| 两当县| 织金县| 资溪县| 宁蒗| 黑水县| 曲靖市| 汾西县| 皋兰县| 清丰县| 岳普湖县| 武冈市| 五家渠市| 华容县| 江孜县| 民县| 沅江市| 芷江|