求一个js正则,要求是数字,可以负数,小数(只能输入一个.)

Martin_Yelvin 2017-08-22 01:54:19
求一个js正则,要求是数字,可以负数,小数(只能输入一个.)
...全文
1692 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
Martin_Yelvin 2017-08-24
  • 打赏
  • 举报
回复
引用 10 楼 LinBilin_ 的回复:
那是你的问题,别人正则给你了,但你怎么用就是另一回事了
  • 打赏
  • 举报
回复
那是你的问题,别人正则给你了,但你怎么用就是另一回事了
Martin_Yelvin 2017-08-23
  • 打赏
  • 举报
回复
引用 8 楼 LinBilin_ 的回复:
忘了你需要负数

var pattern=/^[-+]?(?:[0-9]|[1-9]\d*)(?:\.\d)?$/;
<input type='text' onkeyup="this.value=this.value.replace(/^[-+]?(?:[0-9]|[1-9]\d*)(?:\.\d)?$/,'')" /> 好像不太管事。。
  • 打赏
  • 举报
回复 1
忘了你需要负数

var pattern=/^[-+]?(?:[0-9]|[1-9]\d*)(?:\.\d)?$/;
  • 打赏
  • 举报
回复
这个简单,给你写一个

var pattern=/^(?:[0-9]|[1-9]\d*)(?:\.\d)?$/;
Martin_Yelvin 2017-08-22
  • 打赏
  • 举报
回复
引用 4 楼 zzgzzg00 的回复:
/^[+-]?\d+(?:\.\d+)?$/
,好像不行啊哥
hongmei85 2017-08-22
  • 打赏
  • 举报
回复
<input type="text" onblur="alert(/^-?\d*\.?\d*$/.test(value))">
似梦飞花 2017-08-22
  • 打赏
  • 举报
回复
/^[+-]?\d+(?:\.\d+)?$/
Martin_Yelvin 2017-08-22
  • 打赏
  • 举报
回复
onkeyup="value=value.replace(/[^\-?\d.]/g,'')"
Martin_Yelvin 2017-08-22
  • 打赏
  • 举报
回复
<input type="text" onkeyup="value=value.replace(/[^\-?\d](\.{0,1})/g,'')">
<br>
<br>
<input type="text"onkeyup="value=value.replace(/[^\-?\d.]/g,'')">

<input type="text" onkeyup="value=value.replace(/^([1-9][0-9]*|0)(\.[0-9]+)?$,'')">
Martin_Yelvin 2017-08-22
  • 打赏
  • 举报
回复
百度搜了这几个: https://codepen.io/niexin/pen/OVYpvb
一个不错的数字正则表达式验证的电子参考书。内容预览: 验证数字:^[0-9]*$ 验证n位的数字:^\d{n}$ 验证至少n位数字:^\d{n,}$ 验证m-n位的数字:^\d{m,n}$ 验证零和非零开头的数字:^(0|[1-9][0-9]*)$ 验证有两位小数的正实数:^[0-9]+(.[0-9]{2})?$ 验证有1-3位小数的正实数:^[0-9]+(.[0-9]{1,3})?$ 验证非零的正整数:^\+?[1-9][0-9]*$ 验证非零的负整数:^\-[1-9][0-9]*$ 验证非负整数(正整数 + 0) ^\d+$ 验证非正整数(负整数 + 0) ^((-\d+)|(0+))$ 验证长度为3的字符:^.{3}$ 验证由26个英文字母组成的字符串:^[A-Za-z]+$ 验证由26个大写英文字母组成的字符串:^[A-Z]+$ 验证由26个小写英文字母组成的字符串:^[a-z]+$ 验证由数字和26个英文字母组成的字符串:^[A-Za-z0-9]+$ 验证由数字、26个英文字母或者下划线组成的字符串:^\w+$ 验证用户密码:^[a-zA-Z]\w{5,17}$ 正确格式为:以字母开头,长度在6-18之间,只能包含字符、数字和下划线。 验证是否含有 ^%&',;=?$\" 等字符:[^%&',;=?$\x22]+ 验证汉字:^[\u4e00-\u9fa5],{0,}$ 验证Email地址:^\w+[-+.]\w+)*@\w+([-.]\w+)*\.\w+([-.]\w+)*$ 验证InternetURL:^http://([\w-]+\.)+[\w-]+(/[\w-./?%&=]*)?$ ;^[a-zA-z]+://(w+(-w+)*)(.(w+(-w+)*))*(?S*)?$ 验证电话号码:^(\(\d{3,4}\)|\d{3,4}-)?\d{7,8}$:--正确格式为:XXXX-XXXXXXX,XXXX-XXXXXXXX,XXX-XXXXXXX,XXX-XXXXXXXX,XXXXXXX,XXXXXXXX。 验证身份证号(15位或18位数字):^\d{15}|\d{}18$ 验证一年的12个月:^(0?[1-9]|1[0-2])$ 正确格式为:“01”-“09”和“1”“12” 验证一个月的31天:^((0?[1-9])|((1|2)[0-9])|30|31)$ 正确格式为:01、09和1、31。 整数:^-?\d+$ 非负浮点数(正浮点数 + 0):^\d+(\.\d+)?$ 正浮点数 ^(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*))$ 非正浮点数(负浮点数 + 0) ^((-\d+(\.\d+)?)|(0+(\.0+)?))$ 负浮点数 ^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$ 浮点数 ^(-?\d+)(\.\d+)?$ ×××××××××××××××××××××××××××××××××××××× 以下未经测试,请验证后使用 1.只能输入数字和英文的: 2.只能输入数字的: 3.只能输入全角的: 4.只能输入汉字的: 5.邮件地址验证: var regu = "^(([0-9a-zA-Z]+)|([0-9a-zA-Z]+[_.0-9a-zA-Z-]*[0-9a-zA-Z]+))@([a-zA-Z0-9-]+[.])+([a-zA-Z]{2}|net|NET|com|COM|gov|GOV|mil|MIL|org|ORG|edu|EDU|int|INT)$" var re = new RegExp(regu); if (s.search(re) != -1) { return true; } else { window.alert ("请输入有效合法的E-mail地址 !") return false; } 6.身份证: "^\\d{17}(\\d|x)$" 7.17种正则表达式 "^\\d+$"  //非负整数(正整数 + 0) "^[0-9]*[1-9][0-9]*$"  //正整数 "^((-\\d+)|(0+))$"  //非正整数(负整数 + 0) "^-[0-9]*[1-9][0-9]*$"  //负整数 "^-?\\d+$"    //整数 "^\\d+([url=file://.//d+)?$]\\.\\d+)?$[/url]"  //非负浮点数(正浮点数 + 0) "^(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*))$"  //正浮点数 "^((-\\d+([url=file://.//d+)?)%7C(0+(//.0+)?))$]\\.\\d+)?)|(0+(\\.0+)?))$[/url]"  //非正浮点数(负浮点数 + 0) "^(-(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*)))$"  //负浮点数 "^(-?\\d+)([url=file://.//d+)?$]\\.\\d+)?$[/url]"  //浮点数 "^[A-Za-z]+$"  //由26个英文字母组成的字符串 "^[A-Z]+$"  //由26个英文字母的大写组成的字符串 "^[a-z]+$"  //由26个英文字母的小写组成的字符串 "^[A-Za-z0-9]+$"  //由数字和26个英文字母组成的字符串 "^\\w+$"  //由数字、26个英文字母或者下划线组成的字符串 "^[\\w-]+(\\.[\\w-]+)*@[\\w-]+(\\.[\\w-]+)+$"    //email地址 "^[a-zA-z]+://(\\w+(-\\w+)*)(\\.(\\w+(-\\w+)*))*(\\?\\S*)?$"  //url ============================================= 1.取消按钮按下时的虚线框   在input里添加属性值 hideFocus 或者 HideFocus=true 2.只读文本框内容 在input里添加属性值 readonly 3.防止退后清空的TEXT文档(可把style内容做做为类引用)    4.ENTER键可以让光标移到下一个输入框    5.只能为中文(有闪动)    6.只能数字(有闪动)    7.只能数字(无闪动)    8.只能输入英文和数字(有闪动)    9.屏蔽输入法    10. 只能输入 数字小数点,减号(-) 字符(无闪动)    11. 只能输入两位小数,三位小数(有闪动)    "^\\d+$"  //非负整数(正整数 + 0) "^[0-9]*[1-9][0-9]*$"  //正整数 "^((-\\d+)|(0+))$"  //非正整数(负整数 + 0) "^-[0-9]*[1-9][0-9]*$"  //负整数 "^-?\\d+$"    //整数 "^\\d+([url=file://\\.\\d+)?$]\\.\\d+)?$[/url]"  //非负浮点数(正浮点数 + 0) "^(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*))$"  //正浮点数 "^((-\\d+([url=file://\\.\\d+)?)|(0+(\\.0+)?))$]\\.\\d+)?)|(0+(\\.0+)?))$[/url]"  //非正浮点数(负浮点数 + 0) "^(-(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*)))$"  //负浮点数 "^(-?\\d+)([url=file://\\.\\d+)?$]\\.\\d+)?$[/url]"  //浮点数 "^[A-Za-z]+$"  //由26个英文字母组成的字符串 "^[A-Z]+$"  //由26个英文字母的大写组成的字符串 "^[a-z]+$"  //由26个英文字母的小写组成的字符串 "^[A-Za-z0-9]+$"  //由数字和26个英文字母组成的字符串 "^\\w+$"  //由数字、26个英文字母或者下划线组成的字符串 "^[\\w-]+(\\.[\\w-]+)*@[\\w-]+(\\.[\\w-]+)+$"    //email地址 "^[a-zA-z]+://(\\w+(-\\w+)*)(\\.(\\w+(-\\w+)*))*(\\?\\S*)?$"  //url "^((\d{1,3}(,\d{3})*?)|\d+)(\.\d+)?$ //带逗号的decimal 具体的使用 另:JS 验证输入数字是否为正整数用例: function checkGiveNum(){ if(!checkNum(trimString(document.getElementById("giveNumber").value))){ alert('您只能输入正整数!'); document.getElementById("giveNumber").value = ""; } } function checkNum(str){ //如果为空,则通过校验 if(str == ""){ return true; } if(/^\+?[1-9][0-9]*$/.test(str)){ return true; }else{ return false; } }

87,901

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧