<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>js控制input框只能輸入數字和一位小數點且小數點後面只有兩位小數</title>
</head>
<body>javascript
<h1>js控制input框只能輸入數字和一位小數點且小數點後面只有兩位小數</h1>
<input type="text" onkeyup="clearNoNum(this)" oninput = "value=value.replace(/[^\d.]/g,'')" >
<p>212或 0.66; 過濾 00000,1.10,0.00</p>html
</body>java
<script language="JavaScript" type="text/javascript">
function clearNoNum(obj){this
obj.value = obj.value.replace(/[^\d.]/g,""); //清除「數字」和「.」之外的字符 obj.value = obj.value.replace(/\.{2,}/g,"."); //只保留第一個. 清除多餘的 obj.value = obj.value.replace(".","$#$").replace(/\./g,"").replace("$#$","."); obj.value = obj.value.replace(/^(\-)*(\d+)\.(\d\d).*$/,'$1$2.$3');//只能輸入兩個小數 //若是沒有小數點,不能爲相似 0一、02的金額 if(obj.value.indexOf(".")< 0 && obj.value !=""){ obj.value= parseFloat(obj.value); } //若是有小數點,不能爲相似 1.10的金額 if(obj.value.indexOf(".")> 0 && obj.value.indexOf("0")>2){ obj.value= parseFloat(obj.value); } //若是有小數點,不能爲相似 0.00的金額 if(obj.value.indexOf(".")> 0 && obj.value.lastIndexOf("0")>2){ obj.value= parseFloat(obj.value); }
}
</script> code
</html>htm