欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2019年01月16日 11:10:15   作者:筱月  
這篇文章主要介紹了vue element動(dòng)態(tài)渲染、移除表單并添加驗(yàn)證的實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

又接到新需求了吧~~

背景

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

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

例如:

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

問(wèn)題

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

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

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

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

利用數(shù)組,v-for 循環(huán)方式,可以完美實(shí)現(xiàn)動(dòng)態(tài)渲染和移除,因?yàn)椴僮鞯闹挥袑?duì)象數(shù)組而已

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

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

每個(gè)動(dòng)態(tài)添加的表單都要加上 rule

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

那么對(duì)應(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ū)名稱(chēng):"
  :rules="[{ required: true, message: '可用區(qū)名稱(chēng)不能為空' }]"
  :prop="'azList[' + index + '].azName'"
  label-width="150px"> 
  <el-input placeholder="請(qǐng)輸入可用區(qū)名稱(chēng)" 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="請(qǐng)輸入唯一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="請(qǐng)輸入唯一ID" v-model="item.physicCode" :maxlength="30"></el-input> 
 </el-form-item>
</div>

寫(xiě)在后面

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue - vue.config.js中devServer配置方式

    vue - vue.config.js中devServer配置方式

    今天小編就為大家分享一篇vue - vue.config.js中devServer配置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2019-10-10
  • vue實(shí)現(xiàn)商城上貨組件簡(jiǎn)易版

    vue實(shí)現(xiàn)商城上貨組件簡(jiǎn)易版

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)商城上貨組件簡(jiǎn)易版,50行js代碼實(shí)現(xiàn)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-11-11
  • Vue中Router路由兩種模式hash與history詳解

    Vue中Router路由兩種模式hash與history詳解

    這篇文章主要介紹了Vue中Router路由的兩種模式,分別對(duì)hash模式與history模式作了簡(jiǎn)要分析,有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2021-09-09
  • Vue中如何優(yōu)雅的捕獲 Promise 異常詳解

    Vue中如何優(yōu)雅的捕獲 Promise 異常詳解

    這篇文章主要為大家介紹了Vue中如何優(yōu)雅的捕獲 Promise 異常詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • 區(qū)分vue-router的hash和history模式

    區(qū)分vue-router的hash和history模式

    這篇文章主要介紹了區(qū)分vue-router的hash和history模式,幫助大家更好的理解和學(xué)習(xí)vue路由,感興趣的朋友可以了解下
    2020-10-10
  • 使用vue編寫(xiě)h5公眾號(hào)跳轉(zhuǎn)小程序的實(shí)現(xiàn)代碼

    使用vue編寫(xiě)h5公眾號(hào)跳轉(zhuǎn)小程序的實(shí)現(xiàn)代碼

    這篇文章主要介紹了使用vue編寫(xiě)h5公眾號(hào)跳轉(zhuǎn)小程序,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-11-11
  • Vue3的7種種組件通信詳情

    Vue3的7種種組件通信詳情

    Vue3兼容大部分Vue2的特性,用Vue2代碼開(kāi)發(fā)Vue3都可以,性能上面打包大小減少 41%,初次渲染快 55%,更新快 133%,內(nèi)存使用減少 54%,本篇文章主要介紹Vue3的7種種組件通信,需要的朋友可以參考下面文章的具體內(nèi)容
    2021-09-09
  • vue中keep-alive組件的入門(mén)使用教程

    vue中keep-alive組件的入門(mén)使用教程

    這篇文章主要給大家介紹了關(guān)于vue中keep-alive組件的入門(mén)使用教程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • Vue生命周期函數(shù)調(diào)用詳解

    Vue生命周期函數(shù)調(diào)用詳解

    這篇文章主要介紹了Vue生命周期函數(shù)調(diào)用詳解,本文將實(shí)現(xiàn)Vue生命周期相關(guān)代碼的核心邏輯,從源碼層面來(lái)理解生命周期,感興趣的小伙伴可以參考一下
    2022-08-08
  • Vue3定義全局變量的方式總結(jié)(附代碼)

    Vue3定義全局變量的方式總結(jié)(附代碼)

    vue創(chuàng)建全局變量和方法有很多種,下面這篇文章主要給大家介紹了關(guān)于Vue3定義全局變量的方式,文中通過(guò)代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用vue3具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2024-04-04

最新評(píng)論