详解基于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 相关文章推荐
jquery $.ajax相关用法分享
Mar 16 Javascript
纯javascript判断查询日期是否为有效日期
Aug 24 Javascript
jQuery ajax方法传递中文时出现中文乱码的解决方法
Jul 25 Javascript
Javascript中内建函数reduce的应用详解
Oct 20 Javascript
js导出excel文件的简洁方法(推荐)
Nov 02 Javascript
bootstrap实现动态进度条效果
Mar 08 Javascript
从零开始学习Node.js系列教程四:多页面实现的数学运算示例
Apr 13 Javascript
AngularJS自定义指令实现面包屑功能完整实例
May 17 Javascript
Vue2.0+ElementUI实现表格翻页的实例
Oct 23 Javascript
Vue父子模版传值及组件传值的三种方法
Nov 27 Javascript
如何使用50行javaScript代码实现简单版的call,apply,bind
Aug 14 Javascript
weui中的picker使用js进行动态绑定数据问题
Nov 06 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
杏林同学录(六)
2006/10/09 PHP
async和DOM Script文件加载比较
2014/07/20 PHP
php实现用手机关闭计算机(电脑)的方法
2015/04/22 PHP
PHP数组去重比较快的实现方式
2016/01/19 PHP
JQuery中$之选择器用法介绍
2011/04/05 Javascript
用JS实现一个TreeMenu效果分享
2011/08/28 Javascript
浅析node.js中close事件
2014/11/26 Javascript
JS 对象属性相关(检查属性、枚举属性等)
2015/04/05 Javascript
javaScript实现滚动新闻的方法
2015/07/30 Javascript
JS实现自动切换文字的导航效果代码
2015/08/27 Javascript
js动态生成form 并用ajax方式提交的实现方法
2016/09/09 Javascript
微信小程序购物商城系统开发系列-工具篇的介绍
2016/11/21 Javascript
利用JS轻松实现获取表单数据
2016/12/06 Javascript
AngularJs中Bootstrap3 datetimepicker使用实例
2016/12/13 Javascript
Vue.js学习教程之列表渲染详解
2017/05/17 Javascript
bootstrap3使用bootstrap datetimepicker日期插件
2017/05/24 Javascript
初探js和简单隐藏效果的实例
2017/11/23 Javascript
javascript数据结构之多叉树经典操作示例【创建、添加、遍历、移除等】
2018/08/01 Javascript
Vue项目中使用better-scroll实现菜单映射功能方法
2019/09/11 Javascript
python进程类subprocess的一些操作方法例子
2014/11/22 Python
Python求均值,方差,标准差的实例
2019/06/29 Python
PyQtGraph在pyqt中的应用及安装过程
2019/08/04 Python
python3 使用traceback定位异常实例
2020/03/09 Python
Python greenlet和gevent使用代码示例解析
2020/04/01 Python
Python通过队列来实现进程间通信的示例
2020/10/14 Python
Pam & Gela官网:美国性感前卫女装品牌
2018/07/19 全球购物
Foot Locker澳洲官网:美国运动服和鞋类零售商
2019/10/11 全球购物
运动会广播稿50字
2014/01/26 职场文书
研究生毕业鉴定
2014/01/29 职场文书
店面销售职位的职责
2014/03/09 职场文书
决心书标准格式
2014/03/11 职场文书
幼儿园中班上学期评语
2014/04/18 职场文书
2014国庆节餐厅促销活动策划方案
2014/09/16 职场文书
毕业证代领委托书
2014/09/26 职场文书
AI:如何训练机器学习的模型
2021/04/16 Python
详解nginx安装过程并代理下载服务器文件
2022/02/12 Servers