详解基于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 克隆数组最简单的方法
Feb 12 Javascript
JavaScript高级程序设计(第3版)学习笔记5 js语句
Oct 11 Javascript
Jquery仿IGoogle实现可拖动窗口示例代码
Aug 22 Javascript
node.js中的require使用详解
Dec 15 Javascript
javascript数组输出的两种方式
Jan 13 Javascript
JavaScript操作XML文件之XML读取方法
Jun 09 Javascript
gulp-uglify 与gulp.watch()配合使用时报错(重复压缩问题)
Aug 24 Javascript
JS计算两个时间相差分钟数的方法示例
Jan 10 Javascript
如何优雅的在一台vps(云主机)上面部署vue+mongodb+express项目
Jan 20 Javascript
socket在egg中的使用实例代码详解
May 30 Javascript
vue 自动化路由实现代码
Sep 03 Javascript
Vue 实现可视化拖拽页面编辑器
Feb 01 Vue.js
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
curl实现站外采集的方法和技巧
2014/01/31 PHP
用PHP代替JS玩转DOM的思路及示例代码
2014/06/15 PHP
PHP程序员必须清楚的问题汇总
2014/12/18 PHP
php查询及多条件查询
2017/02/26 PHP
PHP+mysql实现的三级联动菜单功能示例
2019/02/15 PHP
php+Ajax无刷新验证用户名操作实例详解
2019/03/04 PHP
一个符号插入器 中用到的js代码
2007/09/04 Javascript
jQuery ui1.7 dialog只能弹出一次问题
2009/08/27 Javascript
contains和compareDocumentPosition 方法来确定是否HTML节点间的关系
2011/09/13 Javascript
jquery创建并行对象或者合并对象的实现代码
2012/10/10 Javascript
jquery 文本上下无缝滚动,鼠标放上去就停止 小例子
2013/06/05 Javascript
使用apply方法实现javascript中的对象继承
2013/12/16 Javascript
jQuery中scrollTop()方法用法实例
2015/01/16 Javascript
JS实现从顶部下拉显示的带动画QQ客服特效代码
2015/10/24 Javascript
TypeScript学习之强制类型的转换
2016/12/27 Javascript
微信小程序 基础组件与导航组件详细介绍
2017/02/21 Javascript
ztree实现权限横向显示功能
2017/05/20 Javascript
详解vue-cli 构建Vue项目遇到的坑
2017/08/30 Javascript
iframe与主框架跨域相互访问实现方法
2017/09/14 Javascript
详解JSONObject和JSONArray区别及基本用法
2017/10/25 Javascript
在AngularJs中设置请求头信息(headers)的方法及不同方法的比较
2018/09/04 Javascript
layUI实现前端分页和后端分页
2019/07/27 Javascript
vue下的@change事件的实现
2019/10/25 Javascript
python3 selenium 切换窗口的几种方法小结
2018/05/21 Python
Python基于百度云文字识别API
2018/12/13 Python
python动态进度条的实现代码
2019/07/03 Python
python标记语句块使用方法总结
2019/08/05 Python
python实现人工蜂群算法
2020/09/18 Python
如何让IE9以下版本(ie6/7/8)认识html5元素
2013/04/01 HTML / CSS
高中的自我鉴定
2013/12/16 职场文书
家长写给老师的建议书
2014/03/13 职场文书
保密工作承诺书
2014/08/29 职场文书
党员应该树立反腐倡廉的坚定意识思想汇报
2014/09/12 职场文书
2014年实习班主任工作总结
2014/11/08 职场文书
北京青年观后感
2015/06/15 职场文书
Python数据分析之绘图和可视化详解
2021/06/02 Python