gpt4 book ai didi

详解基于element的区间选择组件校验(交易金额)

转载 作者:qq735679552 更新时间:2022-09-27 22:32:09 28 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章详解基于element的区间选择组件校验(交易金额)由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

需求:

这里以项目的需求为例,基本的需求如下:

  1. 分为左右值,包含左右值,正整数
  2. 左侧必须大于等于1,右侧无限大,右侧值必须不小于左侧
  3. 左侧填写数据,右侧标为必填;右侧填写数据,左侧标为必填
  4. 失焦校验成果:

详解基于element的区间选择组件校验(交易金额)

代码如下:(页面) 。

?
1
2
3
4
5
6
7
8
9
10
11
12
<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>

主要思路:

  • 单个表单校验:左侧填写数据,右侧标为必填;右侧填写数据,左侧标为必填、正整数校验、区间校验
  • 关联校验:右侧阈值不得小于左侧阈值

根据上面的思路,单个表单的校验属于公共校验方法,关联校验需要分别校验(因为对比对象不同,且提示语不同),由此在自定义校验中有了如下定义:

公共校验方法:正整数校验、区间校验 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
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( '请输入数字值' ))
   }

关联校验:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
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: '请填写交易金额最小值' , 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: '请填写交易金额最大值' , trigger: 'blur' },
     { validator: this .validateCom, trigger: 'blur' },
     { validator: validateMax, trigger: 'blur' })
    return R
   }

填坑(重点)

很显然,左侧值是小于右侧值的,但是校验提示仍然报错。究其原因,还是关联校验的问题。既然是关联交验,改变其中一个时应该会重新校验两个。很简单,在input改变时,重新校验表单不就OK了吗 。

?
1
2
3
4
5
6
handleMinChange(index) {
    this .$refs.form.validateField( 'list.' + index + '.qttcEndNum' )
   },
   handleMaxChange(index) {
    this .$refs.form.validateField( 'list.' + index + '.qttcStartNum' )
   }

大功告成,忘说了。我的表单是动态从后台获取的,所以校验rules是动态加的!!! 。

到此这篇关于详解基于element的区间选择组件校验(交易金额)的文章就介绍到这了,更多相关element 区间选择组件校验内容请搜索我以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。

原文链接:https://blog.csdn.net/xiaoxiaoxiao_lu/article/details/86621609 。

最后此篇关于详解基于element的区间选择组件校验(交易金额)的文章就讲到这里了,如果你想了解更多关于详解基于element的区间选择组件校验(交易金额)的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

28 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com