input输入框限制只能输入数字,如何实现

我知道用正则表达式。我也写了表达式。但是只是绑定在onkeyup事件上的,这个效果就是输入了一个非数字,然后一闪而消失。这个效果不好...然后我换成onkeydown更不... 我知道用正则表达式。我也写了表达式。
但是只是绑定在onkeyup事件上的,这个效果就是输入了一个非数字,然后一闪而消失。这个效果不好...
然后我换成onkeydown更不行。
我需要的是 其他的字符连输入的资格都没有,而不是输进去了然后在用正则式替换。
就类似easyui-numberbox那样...我想知道这怎么实现的...
展开
 我来答
zhou2003737
2015-01-29 · TA获得超过1427个赞
知道小有建树答主
回答量:1082
采纳率:77%
帮助的人:402万
展开全部
绑定onkeyddown的方法,判断输入的数据是否是数字。

<!DOCTYPE HTML>
<html>
<head>
<title></title>
<script type="text/javascript">
window.onload = function(){
document.getElementById('test').onkeydown = function(e){
var keyCode;
window.event ? keyCode = e.keyCode :keyCode = e.which;
var keyStr = String.fromCharCode(keyCode);
return /\d/.test(keyStr);
}
}
</script>
</head>
<body >
<input type="text" id="test" />
</body>
</html>
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
raochong1992
2017-10-27 · 超过14用户采纳过TA的回答
知道答主
回答量:42
采纳率:87%
帮助的人:12.8万
展开全部
<input type="number" />试试这个?但是

IE
Firefox

Safari 并不兼容。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
轻纱云溪韵
2015-01-27
知道答主
回答量:2
采纳率:0%
帮助的人:2539
展开全部
写一个0-9的字符串然后让输入框中的值循环遍历每一个在0-9的字符串中是否都能找到对应的字符,如果有找不到的就返回false;如果都可以就返回true
追问
能详细一点么,哪个方法返回true
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友211658b42
推荐于2017-10-02 · TA获得超过3383个赞
知道小有建树答主
回答量:606
采纳率:100%
帮助的人:601万
展开全部
function onlyNumber(event){
    var keyCode = event.keyCode;
    if(keyCode<48 || keyCode>57){
        event.keyCode = 0;
    }
}
$(function(){
    $("#numberbox").keydown(onlyNumber);
});

HTML代码:

<input type="text" id="numberbox"/>
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式