中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

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

又接到新需求了吧~~

在右江等地區(qū),都構(gòu)建了全面的區(qū)域性戰(zhàn)略布局,加強(qiáng)發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務(wù)理念,為客戶提供成都網(wǎng)站設(shè)計、成都網(wǎng)站建設(shè) 網(wǎng)站設(shè)計制作按需網(wǎng)站設(shè)計,公司網(wǎng)站建設(shè),企業(yè)網(wǎng)站建設(shè),品牌網(wǎng)站建設(shè),成都全網(wǎng)營銷推廣,外貿(mào)網(wǎng)站制作,右江網(wǎng)站建設(shè)費(fèi)用合理。

背景

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

常見于填寫個人信息、附加內(nèi)容的表單

例如:

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

問題

在實(shí)現(xiàn)之前,提出幾個問題

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

好吧,我當(dāng)時也思考了一會,最后選擇數(shù)組方式,動態(tài)渲染

代碼實(shí)現(xiàn)講解

利用數(shù)組,v-for 循環(huán)方式,可以完美實(shí)現(xiàn)動態(tài)渲染和移除,因?yàn)椴僮鞯闹挥袑ο髷?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() {
   // 點(diǎn)擊添加表單的按鈕,只需要將表單綁定的 value 作為對象 push 到對象數(shù)組
   this.form['azList'].push({
    azName: '',
    logicCode: '',
    physicCode: '',
    weight: ''
   })
  },
  deleteItem(index) {
   // 點(diǎn)擊移除表單的按鈕,根據(jù)點(diǎn)擊的當(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í)有所幫助,也希望大家多多支持創(chuàng)新互聯(lián)。

文章題目:vueelement動態(tài)渲染、移除表單并添加驗(yàn)證的實(shí)現(xiàn)
文章轉(zhuǎn)載:http://www.rwnh.cn/article2/gopjoc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供全網(wǎng)營銷推廣、微信小程序、網(wǎng)站策劃、響應(yīng)式網(wǎng)站、移動網(wǎng)站建設(shè)、服務(wù)器托管

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站建設(shè)網(wǎng)站維護(hù)公司
陆河县| 滦平县| 安顺市| 遂昌县| 阳信县| 蓬莱市| 阿荣旗| 崇明县| 乌鲁木齐市| 宁蒗| 木里| 唐山市| 安远县| 兴城市| 徐闻县| 奎屯市| 婺源县| 永嘉县| 郧西县| 来凤县| 普格县| 楚雄市| 贡嘎县| 淅川县| 阿拉尔市| 宜阳县| 金川县| 永善县| 洛扎县| 武乡县| 南开区| 西乌珠穆沁旗| 东安县| 法库县| 海安县| 剑川县| 秀山| 北宁市| 景德镇市| 滦平县| 辉南县|