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

詳解基于element的區(qū)間選擇組件校驗(yàn)(交易金額)

 更新時間:2021年01月07日 09:45:23   作者:xiaoxiaoxiao_lu  
這篇文章主要介紹了詳解基于element的區(qū)間選擇組件校驗(yàn)(交易金額),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

需求:

這里以項(xiàng)目的需求為例,基本的需求如下:

  1. 分為左右值,包含左右值,正整數(shù)
  2. 左側(cè)必須大于等于1,右側(cè)無限大,右側(cè)值必須不小于左側(cè)
  3. 左側(cè)填寫數(shù)據(jù),右側(cè)標(biāo)為必填;右側(cè)填寫數(shù)據(jù),左側(cè)標(biāo)為必填
  4. 失焦校驗(yàn)成果:

代碼如下:(頁面)

<el-col :span="8" v-if="item.qttccType === 1"> 
 <el-col :span="14">
  <el-form-item :label="item.qttccName" :prop="'list.'+ index + '.startNum'" :rules="item.qttccName === '交易金額' ? startMoneyRule(tIndex) : []">
   <el-input v-model.number="item.qttcStartNum" style="width: 100%;" @change="handleMinChange(index)"></el-input>
  </el-form-item>
 </el-col>
 <el-col :span="10">
  <el-form-item label="~" label-width="10px" :prop="'list.'+ index + '.qttcEndNum'" :rules="item.qttccName === '交易金額' ? endMoneyRule(tIndex) : []">
   <el-input v-model.number="item.qttcEndNum" style="width: 60%;" @change="handleMaxChange(index)"></el-input>
  </el-form-item>
 </el-col>
</el-col>

主要思路:

  • 單個表單校驗(yàn):左側(cè)填寫數(shù)據(jù),右側(cè)標(biāo)為必填;右側(cè)填寫數(shù)據(jù),左側(cè)標(biāo)為必填、正整數(shù)校驗(yàn)、區(qū)間校驗(yàn)
  • 關(guān)聯(lián)校驗(yàn):右側(cè)閾值不得小于左側(cè)閾值

根據(jù)上面的思路,單個表單的校驗(yàn)屬于公共校驗(yàn)方法,關(guān)聯(lián)校驗(yàn)需要分別校驗(yàn)(因?yàn)閷Ρ葘ο蟛煌姨崾菊Z不同),由此在自定義校驗(yàn)中有了如下定義:

公共校驗(yàn)方法:正整數(shù)校驗(yàn)、區(qū)間校驗(yàn)

validateCom(rule, value, callback) {
   const MIN_NUMBER = 1
   const one = Number(value)
   if (Number.isInteger(one)) {
    if (one < MIN_NUMBER) {
     return callback(new Error('輸入值必須大于0'))
    } else if (one.length > 50) {
     callback(new Error('最大長度為50位'))
    }
    return callback()
   }
   return callback(new Error('請輸入數(shù)字值'))
  }

關(guān)聯(lián)校驗(yàn):

startMoneyRule(index) {
   const validateMin = (rule, value, callback) => {
    const one = Number(value)
    const max = Number(this.form.list[index].qttcEndNum)
    if (!max || one < max) {
     return callback()
    }
    return callback(new Error('輸入值不得大于最大閾值'))
   }
   const R = []
   R.push({ required: false, message: '請?zhí)顚懡灰捉痤~最小值', trigger: 'blur' },
    { validator: this.validateCom, trigger: 'blur' },
    { validator: validateMin, trigger: 'blur' })
   return R
  },
  endMoneyRule(index) {
   const validateMax = (rule, value, callback) => {
    const one = Number(value)
    const min = Number(this.form.list[index].qttcStartNum)
    if (!min || one > min) {
     return callback()
    }
    return callback(new Error('輸入值不得小于最小閾值'))
   }
   const R = []
   R.push({ required: false, message: '請?zhí)顚懡灰捉痤~最大值', trigger: 'blur' },
    { validator: this.validateCom, trigger: 'blur' },
    { validator: validateMax, trigger: 'blur' })
   return R
  }

填坑(重點(diǎn))

很顯然,左側(cè)值是小于右側(cè)值的,但是校驗(yàn)提示仍然報錯。究其原因,還是關(guān)聯(lián)校驗(yàn)的問題。既然是關(guān)聯(lián)交驗(yàn),改變其中一個時應(yīng)該會重新校驗(yàn)兩個。很簡單,在input改變時,重新校驗(yàn)表單不就OK了嗎

handleMinChange(index) {
   this.$refs.form.validateField('list.' + index + '.qttcEndNum')
  },
  handleMaxChange(index) {
   this.$refs.form.validateField('list.' + index + '.qttcStartNum')
  }

大功告成,忘說了。我的表單是動態(tài)從后臺獲取的,所以校驗(yàn)rules是動態(tài)加的?。?!

到此這篇關(guān)于詳解基于element的區(qū)間選擇組件校驗(yàn)(交易金額)的文章就介紹到這了,更多相關(guān)element 區(qū)間選擇組件校驗(yàn)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 關(guān)于vue中@click.native.prevent的說明

    關(guān)于vue中@click.native.prevent的說明

    這篇文章主要介紹了關(guān)于vue中@click.native.prevent的說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 解決vue-quill-editor上傳內(nèi)容由于圖片是base64的導(dǎo)致字符太長的問題

    解決vue-quill-editor上傳內(nèi)容由于圖片是base64的導(dǎo)致字符太長的問題

    vue-quill-editor默認(rèn)插入圖片是直接將圖片轉(zhuǎn)為base64再放入內(nèi)容中,如果圖片較多,篇幅太長,就會比較煩惱,接下來通過本文給大家介紹vue-quill-editor上傳內(nèi)容由于圖片是base64的導(dǎo)致字符太長的問題及解決方法,需要的朋友可以參考下
    2018-08-08
  • Vue使用emit傳參,父組件接收不到數(shù)據(jù)的問題及解決

    Vue使用emit傳參,父組件接收不到數(shù)據(jù)的問題及解決

    這篇文章主要介紹了Vue使用emit傳參,父組件接收不到數(shù)據(jù)的問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-09-09
  • ElementUI中el-dropdown-item點(diǎn)擊事件無效問題

    ElementUI中el-dropdown-item點(diǎn)擊事件無效問題

    這篇文章主要介紹了ElementUI中el-dropdown-item點(diǎn)擊事件無效問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue+iview+less+echarts實(shí)戰(zhàn)項(xiàng)目總結(jié)

    vue+iview+less+echarts實(shí)戰(zhàn)項(xiàng)目總結(jié)

    本篇文章是作者通過學(xué)習(xí)vue+iview+less+echarts制作一個小系統(tǒng)后,做的心得以及遇到的坑的總結(jié),值得大家學(xué)習(xí)參考。
    2018-02-02
  • Vue3全局組件注冊的實(shí)現(xiàn)代碼

    Vue3全局組件注冊的實(shí)現(xiàn)代碼

    在這篇文章中,我們將學(xué)習(xí)一下 Vue3 的全局組件注冊是如何實(shí)現(xiàn)的,文中通過代碼示例給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2023-12-12
  • vue.js將時間戳轉(zhuǎn)化為日期格式的實(shí)現(xiàn)代碼

    vue.js將時間戳轉(zhuǎn)化為日期格式的實(shí)現(xiàn)代碼

    這篇文章主要介紹了vue.js將時間戳轉(zhuǎn)化為日期格式的實(shí)現(xiàn)代碼,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-06-06
  • 一文搞懂Vue2中的組件通信

    一文搞懂Vue2中的組件通信

    這篇文章主要為大家介紹了Vue2中的組件通信方式,文中通過示例進(jìn)行了詳細(xì)的介紹,對我們學(xué)習(xí)Vue有一定的幫助,感興趣的小伙伴可以了解一下
    2022-07-07
  • vue實(shí)現(xiàn)滾動加載的表格

    vue實(shí)現(xiàn)滾動加載的表格

    在系統(tǒng)開發(fā)中遇到了這么一個問題:后端一次性返回上百條的數(shù)據(jù),我需要把返回的數(shù)據(jù)全部顯示在表格里,而且甲方爸爸明確指定了表格是不允許使用分頁的??墒钱?dāng)使用a-table裝載上百條數(shù)據(jù)時,頁面出現(xiàn)了明顯的卡頓現(xiàn)象。只能使用滾動加載的方案來代替了。
    2021-06-06
  • Vue3項(xiàng)目引入阿里iconfont圖標(biāo)與字體及使用教程

    Vue3項(xiàng)目引入阿里iconfont圖標(biāo)與字體及使用教程

    Iconfont國內(nèi)功能很強(qiáng)大且圖標(biāo)內(nèi)容很豐富的矢量圖標(biāo)庫,提供矢量圖標(biāo)下載、在線存儲、格式轉(zhuǎn)換等功能,下面這篇文章主要給大家介紹了關(guān)于Vue3項(xiàng)目引入阿里iconfont圖標(biāo)與字體及使用教程,需要的朋友可以參考下
    2023-05-05

最新評論