详解基于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 相关文章推荐
jMessageBox 基于jQuery的窗口插件
Dec 09 Javascript
jQuery EasyUI中对表格进行编辑的实现代码
Jun 10 Javascript
jquery插件之信息弹出框showInfoDialog(成功/错误/警告/通知/背景遮罩)
Jan 09 Javascript
javascript实现日期格式转换
Dec 16 Javascript
javascript中定义类的方法汇总
Dec 28 Javascript
20分钟轻松创建自己的Bootstrap站点
May 12 Javascript
JavaScript实现九九乘法表的简单实例
Jun 07 Javascript
浅谈js数组和splice的用法
Dec 04 Javascript
JavaScript自执行函数和jQuery扩展方法详解
Oct 27 jQuery
详解webpack + react + react-router 如何实现懒加载
Nov 20 Javascript
微信小程序图片选择区域裁剪实现方法
Dec 02 Javascript
TypeScript的安装、使用、自动编译的实现
Apr 10 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
第十二节 类的自动加载 [12]
2006/10/09 PHP
ajax缓存问题解决途径
2006/12/06 PHP
php定时删除文件夹下文件(清理缓存文件)
2013/01/23 PHP
thinkphp四种url访问方式详解
2014/11/28 PHP
实例分析10个PHP常见安全问题
2019/07/09 PHP
安装docker和docker-compose实例详解
2019/07/30 PHP
Laravel统计一段时间间隔的数据方法
2019/10/09 PHP
在PHP中实现使用Guzzle执行POST和GET请求
2019/10/15 PHP
jquery复选框CHECKBOX全选、反选
2008/08/30 Javascript
js 页面输出值
2008/11/30 Javascript
关于JavaScript对象的动态选择及遍历对象
2014/03/10 Javascript
jquery获取html元素的绝对位置和相对位置的方法
2014/06/20 Javascript
Javascript遍历table中的元素示例代码
2014/07/08 Javascript
jquery 操作css样式、位置、尺寸方法汇总
2014/11/28 Javascript
js实现跨域的方法实例详解
2015/06/24 Javascript
jQuery模拟黑客帝国矩阵效果实例
2015/06/28 Javascript
js实现导航栏中英文切换效果
2017/01/16 Javascript
js禁止浏览器的回退事件
2017/04/20 Javascript
jQuery鼠标悬停内容动画切换效果
2017/04/27 jQuery
node.js + socket.io 实现点对点随机匹配聊天
2017/06/30 Javascript
vue在使用ECharts时的异步更新和数据加载详解
2017/11/22 Javascript
ES6 迭代器(Iterator)和 for.of循环使用方法学习(总结)
2018/02/08 Javascript
Vue ElementUi同时校验多个表单(巧用new promise)
2018/06/06 Javascript
解决vue移动端适配问题
2018/12/12 Javascript
基于Python的图像数据增强Data Augmentation解析
2019/08/13 Python
解决django后台管理界面添加中文内容乱码问题
2019/11/15 Python
Python和Anaconda和Pycharm安装教程图文详解
2020/02/04 Python
python opencv圆、椭圆与任意多边形的绘制实例详解
2020/02/06 Python
Django自关联实现多级联动查询实例
2020/05/19 Python
详解KMP算法以及python如何实现
2020/09/18 Python
村主任个人对照检查材料
2014/10/01 职场文书
幼儿园教师节感谢信
2015/01/23 职场文书
小学生心理健康活动总结
2015/05/08 职场文书
围城读书笔记
2015/06/26 职场文书
2015年中秋寄语
2015/07/31 职场文书
CSS3鼠标悬浮过渡缩放效果
2021/04/17 HTML / CSS