vue实现表单输入框数字类型校验功能
创始人
2025-01-15 02:34:30
0

vue实现表单输入框数字类型校验功能

1. 样式代码

     

在HTML表单里使用 input事件来监听输入值的变化,一单数据变化,就触发校验规则。输入框输入的类型 都是字符串类型,要把字符串转换成数字类型。

在HTML中,无论是原生的input元素还是Element UI的el-input组件,当用户在输入框中输入数字时,这些输入值默认会被当作字符串类型处理。

2 methods 正则表达式校验输入的值

//正则表达式校验订单价格输入的值 check(value) {   const Regex = /^\d+(\.\d{1,2})?$/;   if (!Regex.test(value)) {     this.$notify.warning("订单总价请输入正整数或者2位数小数")   } }, 

但是 监听校验 只是对输入值校验,如果用户不听提示,执意提交非数字类型的,还是能提交到后台,导致后台因为字段类型不同而报错。

所以input事件校验可以不要。

报错信息如下:

JSON parse error: Cannot deserialize value of type `java.lang.Double` from String "十": not a valid Double value; nested exception is com.fasterxml.jackson.databind.exc.InvalidFormatException: Cannot deserialize value of type `java.lang.Double` from String "十": not a valid Double value 

3 提交订单时 再校验 如果校验不通过不允许提交表单

3.1 使用vue方法校验

在methods 提交表单的函数,在调后端接口前做校验

save(){ let b = this.checkDataType(Number(this.form.totalPrice));  if (!b) {    this.$notify.warning("订单总价输入的不是数字,请输入数字")    return;  } //下面调接口提交表单 省略 } 

下面的方法复制到methods 用于校验一个变量是否是数字类型,如果是非数字会返回false,如果是小数或者整数返回true

//校验订单总价输入的类型 checkDataType(variable) {   if (typeof variable === 'number') {     return Number.isInteger(variable) || Number.isFinite(variable) && variable % 1 !== 0;   } else {    return false;   } }, 

3.2 再次使用正则表达式校验

所以input事件校验可以不要,但是提交时的校验一定要有,这样才能保证前端传到后台的数据跟实体类的字段类型一致的。

 save(){     let b = this.check(this.form.totalPrice);      if (!b) {        this.$notify.warning("订单总价输入的不是数字,请输入数字")        return;      } }  
//正则表达式校验订单价格输入的值 check(value) {   const Regex = /^\d+(\.\d{1,2})?$/;   if (Regex.test(value)) {     return true   } else {     return false   } }, 

其他方法:

1.v-model.number

elmentUI 提供的数字字符串转换为数字类型,以下是一个使用Element UI的el-input组件并转换输入值为数字类型的示例:

html 

但是,使用方式时,无法输入小数点。可能是我方式不对,铁们,可以尝试一下这种,这种可以的话是比价简单的。

2.InputNumber 计数器

在Element UI中,el-input-number组件是一个专门用于输入和显示数字的计数器。它提供了对数字输入的内置验证和控制,包括限制输入范围、步长等。

:precision=“2” precision 的值必须是一个非负整数,并且不能小于 step 的小数位数。调整精度位数

:step=“0.1” 点击加减符号时增减的数值

  

后端数据类型的获取和校验

前端比较校验传过来的数据必须是数字类型,才不会报错。不然虽然后端加上校验代码也是会报错的的。

这是因为 前端调用接口时,把数据传到后端Spring MVC框架会尝试将请求参数转换为相应的方法参数类型。如果数据类型不匹配或无法转换,Spring会抛出MethodArgumentTypeMismatchException异常。

但这并不意味着后端可以完全依赖于这种自动类型转换和异常处理来进行数据校验。因为用户可能绕过前端校验直接向后端发送请求。因此,后端需要进行数据校验以确保接收到的数据是合法和安全的。

//校验订单总价输入的必须是正整数或者正小数类型 Class purchaseOrderClass = PurchaseOrder.class; Field totalPriceField = purchaseOrderClass.getDeclaredField("totalPrice"); Class type = totalPriceField.getType(); if (!(type.equals(Integer.class) || type.equals(Double.class))){     throw new CustomException("-1","订单总价请输入正整数或者小数数字"); } 

相关内容

热门资讯

透视透明挂!免费雀神挂件怎么安... 您好:这款微信小程序雀神挂件怎么安装游戏是可以开挂的,确实是有挂的,很多玩家在这款微信小程序雀神挂件...
一分钟揭秘!透视辅助器(免费)... 网易游戏辅助软件是一款专注玩家量身打造的游戏记牌类型软件,在网易游戏辅助软件这款游戏中我们可以记录下...
玩家必看科普!皮皮衡阳字牌科技... 玩家必看科普!皮皮衡阳字牌科技,新星游辅助怎么购买,原本有开挂辅助安装(确实有挂);打开点击测试直接...
透视透明!新道游房间,微乐小程... 透视透明!新道游房间,微乐小程序辅助脚本平台(扑克教程!开挂辅助神器);打开点击测试直接进入微信(1...
科技介绍!赣牌圈科技有没有挂,... 大家好,今天小编来为大家解答越乡游义乌辅助器微信免费这个问题咨询软件客服可以免费测试直接加微信(13...
来一盘!红茶楼互娱辅助,来趣广... >>您好:红茶楼互娱辅助确实是有挂的,很多玩家在这款红茶楼互娱辅助游戏中打牌都会发现很多用户的牌特别...
透明神器!wepoker透视最... 透明神器!wepoker透视最简单三个步骤,微信微乐辅助器使用教程(曝光教程辅助开挂下载);无需打开...
六分钟了解!杭州都莱可以装挂吗... 蜀山四川智能辅助插件是一款可以让一直输的玩家,快速成为一个“必胜”的ai辅助神器,有需要的用户可以加...
玩家交流!闲来辅助最新版下载,... 闲来辅助最新版下载开挂教程视频分享装挂详细步骤在当今的网络游戏中,闲来辅助最新版下载作为一种经典的娱...
透视规律!微乐小程序免费黑科技... 透视规律!微乐小程序免费黑科技,wepoker能不能透视(攻略方法辅助平台)1、下载安装好微乐小程序...