Vue ElementUI实现:限制输入框只能输入正整数的问题


Posted in Javascript onJuly 31, 2020

input输入框中禁止输入小数和负数(*只允许输入正整数 *)

最近在做项目中碰见了这么个问题,需要输入数字,但是只能输入正整数,在网上找的没找到自己想要的,所以就自己想了两个办法,在这里跟大家分享一下。(因为是刚毕业,第一次写博客,所以有点生疏,请各位大佬担待一些)

方法一:利用禁止按键的方法,主要是依靠禁止按下减号以及小数点来完成的

Vue ElementUI实现:限制输入框只能输入正整数的问题

首先要监听keyup(键盘按下)事件,因为elementUi上面的input组件监听事件是没有这个事件的,所以可能会报错,所以我们需要加个vue事件的修饰符 .native,代表原生事件的意思。

然后我们传个$event对象进去来获取原生的DOM(可以简单理解为触发事件的本身)

接下来就是在methods中写这个函数了

Vue ElementUI实现:限制输入框只能输入正整数的问题

具体的意思我已经写在上面了,按下键后,可以自己弹出一下keynum和keychar所代表的的字符或者键盘码,根据哪个判断都可以,我选择使用键盘码来判断进入判断后我们就可以做交互了,最后我选择清掉用户所输入的数据。

方法二:利用正则表达式来规避掉小数点和负数

Vue ElementUI实现:限制输入框只能输入正整数的问题

在这里呢使用的就是elementUI的事件了,我们监听一下失去焦点的时候要触发事件,同样的我们要传入进去$event参数

methods中编写函数

Vue ElementUI实现:限制输入框只能输入正整数的问题

这里使用的正则的意思代表的是(针对没有接触过正则的同学,会的大佬们看看有什么错误没):

首先我们先看开头的^和结尾的$这里分别代表匹配字符串的开头以及匹配字符串的结尾,而[1-9]是代表的是匹配1-9其中的数字,所以会过滤掉负数和小数,同时要求开头必须要以1开头,后面的则是匹配以0-9结尾的数字,而*代表的是0次或多次,也就是不限制结尾的数字,合起来的意思就是:我们匹配从1-9中的某个数开头,并且以0-9中的某个数结尾的匹配。

最后呢,就是做的判断了,如果符合我们所定义的正则就不用提示错误了,如果不符合呢,就会提示错误,同时清空数据

下面这些内容是后追加的:

方法三:利用ES6语法includes来规筛掉 . 和 -

1.获取到输入框的值,对输入框内容进行检索

var inputText = document.querySelector('#inputText')

 inputText.addEventListener('input', function(){
  if( this.value.includes('.')){
   console.log('不能输入小数点')
  }else if(this.value.includes('-')){
   console.log('不能输入负数')
  }else{
   console.log('正常')
  }
 })

方法四:利用正则匹配出 . 或者 -

方法是和方法二一样的,但是正则表达式则是:/^\d+\.\d$/

附上两个实例:

let regx = /^\d+\.\d+$/;
let num_two = 1.252;
const newNum_two = regx.test(num_two)
console.log(newNum_two)

解释:

/^d+:以任意一个数字开头 +:出现一次或多次

\.:第二位为小数点

\d+$ :以任意一个数字结尾并且出现一次或多次

let regx_two = /^\-\d\.?\d*$/;
let num_three = -2.53;
const newNum_three = regx_two.test(num_three)
console.log(newNum_three)

解释:

/^\-:以 - 号 开头

\d:第二位肯定是个数字

\.:第三位可能会出现0次或者1次的 .

\d* 以数字 结尾出现0次或多次(这样就可以如果输入的单单是-2的话,也能匹配到)

OK分享到此结束,如果我之后还有什么办法,再来分享给大家,希望能给大家一个参考,也希望大家多多支持三水点靠木!

Javascript 相关文章推荐
Javascript中的Split使用方法与技巧
Mar 09 Javascript
Jquery对象和Dom对象的区别分析
Nov 20 Javascript
AngularJS基础学习笔记之指令
May 10 Javascript
纯javascript代码实现计算器功能(三种方法)
Sep 07 Javascript
Jquery-1.9.1源码分析系列(十一)之DOM操作
Nov 25 Javascript
微信小程序开发(一) 微信登录流程详解
Jan 11 Javascript
JS 学习总结之正则表达式的懒惰性和贪婪性
Jul 03 Javascript
关于react-router/react-router-dom v4 history不能访问问题的解决
Jan 08 Javascript
垃圾回收器的相关知识点总结
May 13 Javascript
layui给下拉框、按钮状态、时间赋初始值的方法
Sep 10 Javascript
layui自定义工具栏的方法
Sep 19 Javascript
vuex存储复杂参数(如对象数组等)刷新数据丢失的解决方法
Nov 05 Javascript
js实现贪吃蛇小游戏(加墙)
Jul 31 #Javascript
vue实现简易图片左右旋转,上一张,下一张组件案例
Jul 31 #Javascript
vue实现给div绑定keyup的enter事件
Jul 31 #Javascript
简单了解JavaScript作用域
Jul 31 #Javascript
基于vue--key值的特殊用处详解
Jul 31 #Javascript
javascript开发实现贪吃蛇游戏
Jul 31 #Javascript
vue 解决无法对未定义的值,空值或基元值设置反应属性报错问题
Jul 31 #Javascript
You might like
php面向对象全攻略 (十) final static const关键字的使用
2009/09/30 PHP
PHP parse_url 一个好用的函数
2009/10/03 PHP
php判断并删除空目录及空子目录的方法
2015/02/11 PHP
php实现用户登陆简单实例
2017/04/04 PHP
浅谈laravel 5.6 安装 windows上使用composer的安装过程
2019/10/18 PHP
jquery 快速回到页首的方法
2013/12/05 Javascript
jquery实现更改表格行顺序示例
2014/04/30 Javascript
离开当前页面前使用js判断条件提示是否要离开页面
2014/05/02 Javascript
基于iframe实现类似于ajax的页面无刷新
2014/05/31 Javascript
JavaScript中window.open用法实例详解
2015/04/15 Javascript
Ionic如何实现下拉刷新与上拉加载功能
2016/06/03 Javascript
两行代码轻松搞定JavaScript日期验证
2016/08/03 Javascript
微信小程序 选择器(时间,日期,地区)实例详解
2016/11/16 Javascript
JS获取鼠标位置距浏览器窗口距离的方法示例
2017/04/11 Javascript
element ui 对话框el-dialog关闭事件详解
2018/02/26 Javascript
JS判断字符串是否为整数的方法--简单的正则判断
2018/07/23 Javascript
PHPStorm中如何对nodejs项目进行单元测试详解
2019/02/28 NodeJs
详解webpack打包vue项目之后生成的dist文件该怎么启动运行
2019/09/06 Javascript
node.js 使用 net 模块模拟 websocket 握手进行数据传递操作示例
2020/02/11 Javascript
JS画布动态实现黑客帝国背景效果
2020/11/08 Javascript
vue穿梭框实现上下移动
2021/01/29 Vue.js
[55:44]OG vs NAVI 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/17 DOTA
Python2.x与Python3.x的区别
2016/01/14 Python
英国蛋糕装饰用品一站式商店:Craft Company
2019/03/18 全球购物
捷克多品牌在线时尚商店:ANSWEAR.cz
2020/10/03 全球购物
有针对性的求职自荐信
2013/11/14 职场文书
人力资源经理自我评价
2014/01/04 职场文书
创新型城市实施方案
2014/03/06 职场文书
认购协议书范本
2014/04/22 职场文书
大三学生学年自我鉴定
2014/09/12 职场文书
教师工作总结范文2014
2014/11/10 职场文书
大学生个人年度总结范文
2015/02/15 职场文书
2015年信访工作总结
2015/04/07 职场文书
2015年审计人员工作总结
2015/05/26 职场文书
意外事故赔偿协议书
2016/03/22 职场文书
企业管理制度设计时要注意的几种“常见病”!
2019/04/19 职场文书