输入框限制输入数字问题

稿件来源: 互联网   撰稿作者: 太阳光   发表日期: 2014-04-09   阅读次数: 90   查看权限: 游客查看

输入框限制输入数字问题

早期限制输入框输入数字有这么一种方法:

<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)
共有0 条评论 发言请遵守【相关规定

网友评论

会员头像
发 表同步腾讯微博    验证码:  点击更新请先登陆
  • 暂无评论
关闭模块文章图片 article Pictrue
  • 我的妈妈爸爸
  • 基于koa2+mysql+vue2.0+Element阳光内容管理系统
  • 代码覆盖率工具 Istanbul 入门教程
  • 全栈工程师的武器——MEAN
  • 9款超炫的 CSS3 复选框(Checkbox)
  • 微信开发在线翻译功能
  • CSS3那些不为人知的高级属性
  • 给easyui的datebox添加清空事件
  • flash写字效果
  • kendoUI系列教程之DropDownList下拉菜单
  • kendoUI系列教程之datetimepicker日期时间选择
  • kendoUI系列教程之datepicker日期选择
  • kendoUI系列教程之combobox下拉列表框
  • kendoUI系列教程之colorpicker
  • kendoUI系列教程之calendar日历表
  • kendoUI系列教程之autocomplete自动补齐