文章分类 Classification
输入框限制输入数字问题
稿件来源: 互联网 撰稿作者: 太阳光 发表日期: 2014-04-09 阅读次数: 89 查看权限: 游客查看
输入框限制输入数字问题
早期限制输入框输入数字有这么一种方法:
<input onkeyup="if(isNaN(value))execCommand('undo')" onafterpaste="if(isNaN(value))execCommand('undo')">
明显就不能支持大部分浏览器,只能在IE下乱搞,又是IE的错。
一般我们采取正侧匹配替换法:
<input onkeyup="this.value=this.value.replace(/\D/g,'')" onafterpaste="this.value=this.value.replace(/\D/g,'')">
也就是敲键盘后或者粘贴后把非数字的内容全部清除。当然有时我们还是希望有正负号和小数点呀:
<input onkeyup="this.value=this.value.replace(/[^\d+-\.]/g,'')" onafterpaste="this.value=this.value.replace(/[^\d+-\.]/g,'')">
正侧规则就变成除了正负号小数点和数字其他全清除了。但是仍有问题呀,正负号小数点可以多次输入这可不符合规则的:
<input type="text" id="tt" onblur="this.value=this.value.replace(/^(-)*(\d+)\.(\d\d).*$/,'$1$2.$3')" style="ime-mode: disabled;"> <script type="text/javascript"> document.getElementById("tt").onkeydown=function(e){ e=e||window.event; var k=e.keyCode|| e.which; if(k>47&&k<58&&!e.shiftKey||k>95&&k<106||k==8||k==46||k==37||k==39){ return !0;//按0123456789 backspace delete <-- --> }else if(k==109||k==173&&!e.shiftKey){ return this.value=="";//按负号-,必须第一位输入负号 }else if(k==110||k==190&&!e.shiftKey){ return !~this.value.indexOf(".") && this.value!="";//输入小数点,只能输入一次且值不能为空 }else{ return !1; } }; </script>
这个单纯从敲键盘输入上来说是比较好的,首先使用style禁止了中文,韩文,日文等输入法,同时对负号小数点输入有限制,离开焦点后格式化小数点后只可两位小数。唯一的是仍没对粘贴行为作限制。
关键词: 输入框,input,数字 编辑时间: 2014-04-09 11:57:00
0
高兴0
支持0
搞笑0
不解0
谎言0
枪稿0
震惊0
无奈0
无聊0
反对0
愤怒
0%(0)
0%(0)
- 中搜索:输入框限制输入数字问题
- 中搜索:输入框限制输入数字问题
- 暂无评论
文章图片 article Pictrue
网友评论