在浏览器验证正则字符时,如果输入的是数字带小数点后面不再输入数字,那么浏览器会自动截取掉小数点,即:输入"1.",浏览器会处理成"1"
唔…因此当我为求方便直接在浏览器中输出表达式时就踩坑了 = =
首先我先写了一个验证最多可保留两位小数的正则:
var reg = /^\d+(.\d{1,2})?$/;
\d:0-9的数字
^\d:以0-9数字开头的表达式
^\d+:以一至多个0-9数字开头的表达式
( ):括号里是一个整体
(.\d{1,2}):. 小数点 、d{1,2} 一至两位数字
(.\d{1,2})?:小数(小数点 + 一至两位小数)限制出现零到一次
(.\d{1,2})?$:若存在小数点,则以小数点后的一至两位小数结尾
在页面中写一个输入框和点击按钮,测试校验是否成功:
浏器F12打开控制台查看效果:
在这里入图片描述
可以看到输入框输入1.后正常检验是false,然而如果在浏览器中输入校验规则和字符串则不然:
在这里入图片描述
如果输入个带小数点的数字,后面又不再输入数字时,浏览器会自动忽略掉小数点,因而检验"1."类似的格式相当于校验“1”,结果自然是true。
仅记录为主,若有什么错误还望包涵指出
对于文本框输入的校验有不同的思路,本例采用了正则表达式匹配的方法。
1、即时验证:
为了即时对文本框内容进行验证,可以利用控件的validating事件,当控件失去焦点时,便会触发该事件。
2、正则表达式:
将要验证的有效格式写成正则表达式,不仅可以方便快捷地进行匹配,而且对于以后需求更改时也易于修改(只需修改正则表达式即可)。
利用正则表达式时,需要添加引用:< usingSystem.Text.RegularExpressions; >
3、验证完成:
验证通过后进行的操作可以使用控件的validated事件。例如,如果在验证不通过时有错误提示的话,那么验证通过时就可以给出验证通过的提示。该事件可根据实际需要选用。
4、正常退出:
在Validating事件中做验证处理时,如果验证不通过,本例希望焦点仍停留在该文本框内,即只有输入合法才能进行其他操作。这样的负作用之一就是用户在输入不合法时也无法正常退出程序,因此为使关闭程序的操作不受文本框验证的影响而正常使用,可以在FormClosing事件中添加e.Cancel=false来解决。
5、限制输入长度:
如果用户不小心压住了某个数字键,此时文本框里已经输入了100多位的数据,而且又恰好点击了“提交”按钮时,你能保证后台代码能接受这个结果吗?你如果也有这样的担心,那就试试控件的maxLength属性吧。
6、禁用输入法:
本例要求只能输入数字,因此如果禁用输入法后会省去很多麻烦。禁用后,无法直接输入中文,也无法“直接”输入全角字符。去查查控件的ImeMode属性,设置为disabled后就可以了。
7、全角字符串的处理:
知道上一步为什么说禁用输入法后无法“直接”输入全角字符吗?因为还可以“间接”输入!是的,那就是将全角字符串复制后粘贴过来。不要以为抽风的人才会这么无聊帮你去找Bug,程序员还是应该尽量把可能的异常先做好预防。(当然,禁用文本框的粘贴功能也不错,本例为照顾用户可能存在的粘贴较长数据的需要,没有禁用。大家可以自行搜下禁用粘贴的资料。)
如果文本框里含全角字符,在后期做数据运算时很容易出问题,本例解决方法是先检查,若是全角字符串则转换为半角字符串。
心得体会:
写出一个完全正确且符合自己要求的正则表达式确实需要好好构思,尤其是匹配内容较复杂时。但也不必担心,如果一个表达式完不成,可以写多个表达式然后“或”运算。在写正则表达式时不要盲目地参看网上已有的表达式,最好做个测试程序验证下,因为不同的语言正则表达式语法会有细微的不同。
对于正则表达式,大家先对照着MSDN上的介绍,熟悉每个符号的意思,再去理解别人写的表达式,慢慢就能写出自己的表达式了。对于正则表达式的理解,不妨想想中学学过的“排列组合”,会有用的。用排列组合把表达式中可能的各个分支完整走一遍,就都懂了
^\d+(\.\d+)?$
不知道,lz还能不能看得到,不过,提醒你一下,你的正则只错误的!
比如:[0-9]{0} 是没有用的
还有,.24也是可以匹配的吧
另,你采纳的那个答案,小数点在前面也是可以的,真发愁你们治学的态度!
举个例子:
/[^\d\.]/g,''
发错地方了~~~
LZ,你这个还是错的。。。。。真服你了,严谨点啊. /^\d+\.{0,1}\d*$/