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

vue  elementUI 表單嵌套驗(yàn)證的實(shí)例代碼

 更新時(shí)間:2019年11月06日 14:42:27   作者:enjoylife  
這篇文章主要介紹了vue + elementUI 表單嵌套驗(yàn)證,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下

一:表單一級(jí)驗(yàn)證

element中from組件內(nèi)表單驗(yàn)證通過使用el-form標(biāo)簽,綁定model和rules屬性進(jìn)行表單驗(yàn)證

<el-form ref="form" :model="form" :rules="rules" label-width="110px" @submit.native.prevent>
<el-form-item label="客戶名稱:" size="small" prop="belongId">
  <el-input v-show="false" v-model="form.belongId"></el-input>
  <ComSelectorCustomer :value="form.customerName" @change="choice"></ComSelectorCustomer>
</el-form-item>

簡(jiǎn)單的表單驗(yàn)證很簡(jiǎn)單,在prop內(nèi)綁定驗(yàn)證屬性,然后在rules對(duì)象內(nèi)定義驗(yàn)證方法

rules: {
     belongId: [{
      required: true,
      message: '不能為空',
      trigger: 'change'
     }]
}

二:模板一次循環(huán)渲染時(shí)表單驗(yàn)證

<el-row v-for="(item, index) in form.warehouseList" :key="index">
  <el-col :span="21">
    <el-form-item label="廠庫(kù)名稱:" size="small" :prop="'warehouseList.' + index + '.factoryName'">
      <el-select
       v-model="item.factoryName"
       clearable
       filterable>
       <el-option
         v-for="(child, ind) in factoryList"
         :key="ind"
         :label="child.label"
         :disabled="child.disabled"
         :value="child.value"></el-option>
      </el-select>
    </el-form-item>
   </el-col>
</el-row>

循環(huán)內(nèi)模板驗(yàn)證prop綁定值就是一個(gè)問題了,因?yàn)樗茄h(huán)出來的沒辦法直接寫死在內(nèi),所以prop就需要?jiǎng)討B(tài)綁定驗(yàn)證屬性,這里需要注意一下,動(dòng)態(tài)prop內(nèi)綁定的是要和form內(nèi)定義的屬性名以及model綁定的值要對(duì)應(yīng)上。比如上面prop里的factoryName,form.warehouseList里子元素也要有這個(gè)屬性,select中model綁定的也應(yīng)該是factoryName。因?yàn)槭茄h(huán)出來的,所以model綁定的就是‘item.factoryName'。

如果prop內(nèi)綁定的驗(yàn)證屬性名對(duì)應(yīng)不上,控制臺(tái)一般都會(huì)報(bào)下面這個(gè)錯(cuò)誤

 ![cuowu.png](/img/bVbzWSa)

三:循環(huán)嵌套循環(huán)的表單驗(yàn)證

比如說是這種:

from: {
    warehouseList: [{
      productList: [{
        productNumber: '',
        productUnitPrice: ''
      }]
    }]
  }

要是需要監(jiān)聽productList中的productNumber,并且進(jìn)行驗(yàn)證,這就是第三層的驗(yàn)證。

<div v-for="(itemChild, itemIndex) in item.productList" :key="itemIndex">
   <el-col :span="9">
   <el-form-item label="客戶品名:" label-width="110px" size="small" :prop="'warehouseList.' + index + '.productList.' + itemIndex + '.productName'">
    <el-input v-show="false" v-model="itemChild.productName"></el-input>
    <ComSelectorProduct :value="itemChild.productName"
    @change="choice"></ComSelectorProduct>
   </el-form-item>
 </el-col>
 <el-col :span="4">
   <el-form-item label="數(shù)量:" label-width="60px" size="small" :prop="'warehouseList.' + index + '.productList.' + itemIndex + '.productNumber'">
    <el-input clearable v-model="itemChild.productNumber" placeholder="數(shù)量"></el-input>
   </el-form-item>
 </el-col>
</div>

prop內(nèi)綁定的值需要把第一層循環(huán)時(shí)的父元素warehouseList一并寫上一直寫到input內(nèi)綁定的model值

:prop="'warehouseList.' + index + '.productList.' + itemIndex + '.productName'"

驗(yàn)證方法:

setRulesProduct() {
        let that = this
        let list1 = that.form.warehouseList
        // let list2 = that.form.warehouseList.productList
        if (list1 && list1.length) {
          list1.forEach((item, i) => {
            that.rules['warehouseList.' + i + '.factoryName'] = [{
              required: true,
              message: '請(qǐng)選擇廠庫(kù)',
              trigger: 'change'
            }]
            that.rules['warehouseList.' + i + '.orderNumber'] = [{
              required: true,
              min: 1,
              max: 20,
              validator: (rule, value, callback) => {
                if (!value) {
                  callback(new Error('訂單號(hào)不能為空'))
                } else if (value.length < 1 || value.length > 20) {
                  callback(new Error('訂單號(hào)請(qǐng)保持在1-20字符內(nèi)'))
                } else {
                  callback()
                }
              },
              trigger: 'blur'
            }]
            that.rules['warehouseList.' + i + '.deliveryTime'] = [{
              required: true,
              message: '請(qǐng)選擇日期',
              trigger: 'blur'
            }]

            if (item.productList && item.productList.length) {
              item.productList.forEach((childItem, childIndex) => {
                that.rules['warehouseList.' + i + '.productList.' + childIndex + '.productName'] = [{
                  required: true,
                  message: '請(qǐng)選擇產(chǎn)品',
                  trigger: 'change'
                }]
                that.rules['warehouseList.' + i + '.productList.' + childIndex + '.productNumber'] = [{
                  required: true,
                  min: 1,
                  max: 20,
                  validator: (rule, value, callback) => {
                    if (!value) {
                      callback(new Error('產(chǎn)品數(shù)量不能為空'))
                    } else if (value.length < 1 || value.length > 20) {
                      callback(new Error('產(chǎn)品數(shù)量請(qǐng)保持在1-20字符內(nèi)'))
                    } else {
                      callback()
                    }
                  },
                  trigger: 'blur'
                }]
                that.rules['warehouseList.' + i + '.productList.' + childIndex + '.productUnitPrice'] = [{
                  required: true,
                  message: '請(qǐng)?zhí)顚憜蝺r(jià)',
                  trigger: 'blur'
                }]
              })
            }
          })
        }
      }

在組件創(chuàng)建時(shí)調(diào)用次方法就可以了。多層嵌套驗(yàn)證就搞定了,互不影響。

最重要的一點(diǎn)就是 循環(huán)時(shí)prop內(nèi)綁定的驗(yàn)證屬性名 一定要和model綁定的值相對(duì)應(yīng)上,循環(huán)嵌套過多的就需要一直往上層找,找到最上層元素。

總結(jié)

以上所述是小編給大家介紹的vue + elementUI 表單嵌套驗(yàn)證,希望對(duì)大家有所幫助,如果大家有任何疑問請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

相關(guān)文章

  • vue+webpack 更換主題N種方案優(yōu)劣分析

    vue+webpack 更換主題N種方案優(yōu)劣分析

    這篇文章主要介紹了vue+webpack 更換主題N種方案優(yōu)劣分析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • Element中Slider滑塊的具體使用

    Element中Slider滑塊的具體使用

    這篇文章主要介紹了Element中Slider滑塊的具體使用,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • 基于Vue實(shí)現(xiàn)微前端的示例代碼

    基于Vue實(shí)現(xiàn)微前端的示例代碼

    這篇文章主要介紹了基于Vue實(shí)現(xiàn)微前端的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-04-04
  • Vue插槽簡(jiǎn)介和使用示例詳解

    Vue插槽簡(jiǎn)介和使用示例詳解

    插槽就是子組件中的提供給父組件使用的一個(gè)占位符,用<slot></slot>?表示,父組件可以在這個(gè)占位符中填充任何模板代碼,如?HTML、組件等,填充的內(nèi)容會(huì)替換子組件的<slot></slot>標(biāo)簽,這篇文章主要介紹了Vue插槽的理解和使用,需要的朋友可以參考下
    2023-03-03
  • 使用vux實(shí)現(xiàn)上拉刷新功能遇到的坑

    使用vux實(shí)現(xiàn)上拉刷新功能遇到的坑

    最近公司在研發(fā)app,選擇了基于Vue框架的vux組件庫(kù),現(xiàn)總結(jié)在實(shí)現(xiàn)上拉刷新功能遇到的坑,感興趣的朋友參考下吧
    2018-02-02
  • vue實(shí)現(xiàn)簡(jiǎn)易圖片左右旋轉(zhuǎn),上一張,下一張組件案例

    vue實(shí)現(xiàn)簡(jiǎn)易圖片左右旋轉(zhuǎn),上一張,下一張組件案例

    這篇文章主要介紹了vue實(shí)現(xiàn)簡(jiǎn)易圖片左右旋轉(zhuǎn),上一張,下一張組件案例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-07-07
  • 詳解vue-cli快速構(gòu)建vue應(yīng)用并實(shí)現(xiàn)webpack打包

    詳解vue-cli快速構(gòu)建vue應(yīng)用并實(shí)現(xiàn)webpack打包

    這篇文章主要介紹了詳解vue-cli快速構(gòu)建vue應(yīng)用并實(shí)現(xiàn)webpack打包,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-12-12
  • antd-日歷組件,前后禁止選擇,只能選中間一部分的實(shí)例

    antd-日歷組件,前后禁止選擇,只能選中間一部分的實(shí)例

    這篇文章主要介紹了antd-日歷組件,前后禁止選擇,只能選中間一部分的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2020-10-10
  • vue實(shí)現(xiàn)購(gòu)物車拋物線小球動(dòng)畫效果的方法詳解

    vue實(shí)現(xiàn)購(gòu)物車拋物線小球動(dòng)畫效果的方法詳解

    這篇文章主要介紹了vue實(shí)現(xiàn)購(gòu)物車拋物線小球動(dòng)畫效果的方法,結(jié)合實(shí)例形式較為詳細(xì)的分析了vue.js實(shí)現(xiàn)拋物線動(dòng)畫效果購(gòu)物車功能相關(guān)原理與操作注意事項(xiàng),需要的朋友可以參考下
    2019-02-02
  • Vue頁(yè)面生成PDF的最佳方法推薦

    Vue頁(yè)面生成PDF的最佳方法推薦

    公眾中經(jīng)常會(huì)有這種場(chǎng)景,一些合同、協(xié)議等的頁(yè)面需要進(jìn)行下載,而且需要和頁(yè)面保持一致,下面這篇文章主要給大家介紹了關(guān)于Vue頁(yè)面生成PDF的最佳方法,需要的朋友可以參考下
    2022-05-05

最新評(píng)論