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


Posted in Javascript onJanuary 07, 2021

需求:

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

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

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

代码如下:(页面)

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

主要思路:

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

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

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

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('请输入数字值'))
  }

关联校验:

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

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

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

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

Javascript 相关文章推荐
JavaScript 学习历程和心得分享
Dec 12 Javascript
解析Jquery取得iframe中元素的几种方法
Jul 04 Javascript
javascript:void(0)使用探讨
Aug 27 Javascript
JavaScript模拟实现键盘打字效果
Jun 29 Javascript
jquery实现的用户注册表单提示操作效果代码分享
Aug 28 Javascript
为何JS操作的href都是javascript:void(0);呢
Nov 12 Javascript
老生常谈 js中this的指向
Jun 30 Javascript
js实现的光标位置工具函数示例
Oct 03 Javascript
js实现模糊匹配功能
Feb 15 Javascript
javascript数据类型中的一些小知识点(推荐)
Apr 18 Javascript
解决vue-cli项目开发运行时内存暴涨卡死电脑问题
Oct 29 Javascript
vue 在methods中调用mounted的实现操作
Aug 07 Javascript
el-table表头根据内容自适应完美解决表头错位和固定列错位
Jan 07 #Javascript
vue3中轻松实现switch功能组件的全过程
Jan 07 #Vue.js
vue+elementui通用弹窗的实现(新增+编辑)
Jan 07 #Vue.js
微信小程序onShareTimeline()实现分享朋友圈
Jan 07 #Javascript
JavaScript实现滑块验证解锁
Jan 07 #Javascript
js删除指定位置超链接中含有百度与360的标题
Jan 06 #Javascript
基于element-ui封装表单金额输入框的方法示例
Jan 06 #Javascript
You might like
Smarty安装配置方法
2008/04/10 PHP
PHP 反向排序和随机排序代码
2010/06/30 PHP
深入理解:XML与对象的序列化与反序列化
2013/06/08 PHP
PHP图片裁剪函数(保持图像不变形)
2014/05/04 PHP
php工具型代码之印章抠图
2018/07/18 PHP
PHP实现对数字分隔加千分号的方法
2019/03/18 PHP
window.open的功能全解析
2006/10/10 Javascript
JavaScript中的其他对象
2008/01/16 Javascript
javascript的console.log()用法小结
2012/05/31 Javascript
jquery如何把参数列严格转换成数组实现思路
2013/04/01 Javascript
jQuery计算textarea中文字数(剩余个数)的小程序
2013/11/28 Javascript
如何从jQuery的ajax请求中删除X-Requested-With
2013/12/11 Javascript
javascript实现微信分享
2014/12/23 Javascript
纯javascript实现图片延时加载方法
2015/08/21 Javascript
不使用script导入js文件的几种方法
2016/10/27 Javascript
BootStrap中
2016/12/10 Javascript
详解js中Number()、parseInt()和parseFloat()的区别
2016/12/20 Javascript
简单实现js倒计时功能
2017/02/13 Javascript
使用Angular CLI从蓝本生成代码详解
2018/03/24 Javascript
在element-ui的el-tree组件中用render函数生成el-button的实例代码
2018/11/05 Javascript
JS实现表单中点击小眼睛显示隐藏密码框中的密码
2020/04/13 Javascript
小程序实现左滑删除的效果的实例代码
2020/10/19 Javascript
python实现根据主机名字获得所有ip地址的方法
2015/06/28 Python
用Python分析3天破10亿的《我不是药神》到底神在哪?
2018/07/12 Python
python实现贪吃蛇游戏
2020/03/21 Python
jenkins配置python脚本定时任务过程图解
2019/10/29 Python
如何基于pythonnet调用halcon脚本
2020/01/20 Python
Python实现猜年龄游戏代码实例
2020/03/25 Python
python接入支付宝的实例操作
2020/07/20 Python
HTML5通用接口详解
2016/06/12 HTML / CSS
27个经典Linux面试题及答案,你知道几个?
2014/03/11 面试题
喝酒检查书范文
2014/02/23 职场文书
《守株待兔》教学反思
2014/03/01 职场文书
2014年社区国庆节活动方案
2014/09/16 职场文书
学校师德师风整改方案
2014/10/28 职场文书
PostgreSQL怎么创建分区表详解
2022/06/25 PostgreSQL