用javascript验证只可以输入数字 小数点 和 - 怎么写啊!
2个回答
展开全部
楼上的答案已经很正确了,可能是因为你是初学,没弄明白。
那就仔细地说一下,
比如你有一个input:<input type = 'text' value = ''/>
那么,你可以在里面加入一个键盘事件来侦测用户的输入:<input type = 'text' value = '' onkeyup = 'num(this)'/>
其中,onkeyup是指用户的键盘只要有键抬了起来,其中的this是指input这个输入控件对象
然后我们把num()这个方法建立一下:
function num(th){
//这一行执行的事情比较多,但无非就是把用户输入的那些非数字啦,非小数点啦,非减号啦都去掉,当然,这个是不禁止用户输入两个以上的小数点,如果你需要这么精确,可以追问。
th.value = th.value.replace(/[^\d\.\-]*$/g, '');
}
把以上程序整合一下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script type="text/javascript">
function num(th){
th.value = th.value.replace(/[^\d\.\-]*$/g, '');
}
</script>
</head>
<body>
<input type="text" onkeyup = 'num(this)'/>
</body>
</html>
那就仔细地说一下,
比如你有一个input:<input type = 'text' value = ''/>
那么,你可以在里面加入一个键盘事件来侦测用户的输入:<input type = 'text' value = '' onkeyup = 'num(this)'/>
其中,onkeyup是指用户的键盘只要有键抬了起来,其中的this是指input这个输入控件对象
然后我们把num()这个方法建立一下:
function num(th){
//这一行执行的事情比较多,但无非就是把用户输入的那些非数字啦,非小数点啦,非减号啦都去掉,当然,这个是不禁止用户输入两个以上的小数点,如果你需要这么精确,可以追问。
th.value = th.value.replace(/[^\d\.\-]*$/g, '');
}
把以上程序整合一下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>无标题文档</title>
<script type="text/javascript">
function num(th){
th.value = th.value.replace(/[^\d\.\-]*$/g, '');
}
</script>
</head>
<body>
<input type="text" onkeyup = 'num(this)'/>
</body>
</html>
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询