亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue  elementUI 表單嵌套驗證的實例代碼

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

一:表單一級驗證

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

<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>

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

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

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

<el-row v-for="(item, index) in form.warehouseList" :key="index">
  <el-col :span="21">
    <el-form-item label="廠庫名稱:" 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)模板驗證prop綁定值就是一個問題了,因為它是循環(huán)出來的沒辦法直接寫死在內(nèi),所以prop就需要動態(tài)綁定驗證屬性,這里需要注意一下,動態(tài)prop內(nèi)綁定的是要和form內(nèi)定義的屬性名以及model綁定的值要對應(yīng)上。比如上面prop里的factoryName,form.warehouseList里子元素也要有這個屬性,select中model綁定的也應(yīng)該是factoryName。因為是循環(huán)出來的,所以model綁定的就是‘item.factoryName'。

如果prop內(nèi)綁定的驗證屬性名對應(yīng)不上,控制臺一般都會報下面這個錯誤

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

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

比如說是這種:

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

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

<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)時的父元素warehouseList一并寫上一直寫到input內(nèi)綁定的model值

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

驗證方法:

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: '請選擇廠庫',
              trigger: 'change'
            }]
            that.rules['warehouseList.' + i + '.orderNumber'] = [{
              required: true,
              min: 1,
              max: 20,
              validator: (rule, value, callback) => {
                if (!value) {
                  callback(new Error('訂單號不能為空'))
                } else if (value.length < 1 || value.length > 20) {
                  callback(new Error('訂單號請保持在1-20字符內(nèi)'))
                } else {
                  callback()
                }
              },
              trigger: 'blur'
            }]
            that.rules['warehouseList.' + i + '.deliveryTime'] = [{
              required: true,
              message: '請選擇日期',
              trigger: 'blur'
            }]

            if (item.productList && item.productList.length) {
              item.productList.forEach((childItem, childIndex) => {
                that.rules['warehouseList.' + i + '.productList.' + childIndex + '.productName'] = [{
                  required: true,
                  message: '請選擇產(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ù)量請保持在1-20字符內(nèi)'))
                    } else {
                      callback()
                    }
                  },
                  trigger: 'blur'
                }]
                that.rules['warehouseList.' + i + '.productList.' + childIndex + '.productUnitPrice'] = [{
                  required: true,
                  message: '請?zhí)顚憜蝺r',
                  trigger: 'blur'
                }]
              })
            }
          })
        }
      }

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

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

總結(jié)

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

相關(guān)文章

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

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

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

    Element中Slider滑塊的具體使用

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

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

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

    Vue插槽簡介和使用示例詳解

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

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

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

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

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

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

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

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

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

    vue實現(xiàn)購物車拋物線小球動畫效果的方法詳解

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

    Vue頁面生成PDF的最佳方法推薦

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

最新評論