JavaScript中的十进制数

3
文本框应该只接受 JavaScript 中的十进制值,而不是任何其他特殊字符。它不应该接受超过一个“.”,例如,它不应该接受 6.....12。有人可以帮忙吗?
6个回答

1

0

如果您的意思是您不希望在字段中输入除整数或小数以外的任何内容,那么您需要在每次按键时查看该值。要捕获粘贴的输入,请在 onchange 事件中再次检查它。

textbox.onkeyup=textbox.onchange=function(e){
    e= window.event? event.srcElement: e.target;
    var v= e.value;
    while(v && parseFloat(v)!= v) v= v.slice(0, -1);
    e.value= v;
}

0

可能您想在将表单输入发送到服务器之前验证它。以下是一些示例:

<html>
   <head>
      <title>Form Validation</title>
      <script type="text/javascript">
         function validate(){
            var field = document.getElementById("number");
            if(field.value.match(/^\d+(\.\d*)?$/)){
               return true;
            } else {
               alert("Not a number! : "+field.value);
               return false;
            }
         }
      </script>
   </head>
   <body>
      <form action="#" method="post" onsubmit="return validate();">
         <input type="text" id="number" width="15" /><br />
         <input type="submit" value="send" />
      </form>
   </body>
</html>

0

我刚刚匆忙写了这个。有用吗?

<html>
<head>
<script type="text/javascript">
function validNum(theField) {
  val = theField.value;
  var flt = parseFloat(val);
  document.getElementById(theField.name+'Error').innerHTML=(val == "" || Number(val)==flt)?"":val + ' is not a valid (decimal) number';
}
window.onload=function(){
  validNum(document.getElementById('num'));
}
</script>
</head>
<body>
<form>
<input type="text" name="num" id="num"
onkeyup="return validNum(this)" /> <span id="numError"></span>
</form>
</body>
</html>

0
你可以使用 Regex.test 方法:
if (/\d+(\.\d{1,2})/.test(myTextboxValue)) //OK...

0

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接