只能输出整数:

<input type="text" name="text" onkeyup="this.value=this.value.replace(/\D/g,'')" onpaste="this.value=this.value.replace(/\D/g,'')" />

只能输出数字,包含小数点:

<input type="text" name="text" onkeyup="this.value=this.value.replace(/[^0-9.]/g,'')" />
注解:
这里的正则用途是输出的值不是数字就替换为空。
援用
onkeyup 事件会在键盘按键被松开时产生,onpaste 是粘贴触发
援用
replace() 办法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串
援用
\D:相似[ ^0-9 ] 非数字 g :全局匹配

管制input只能输出数字和两位小数

<input type="text" name="je" onkeyup="clearNum(this)" />
function clearNum(obj){    obj.value = obj.value.replace(/[^\d.]/g,""); //革除"数字"和"."以外的字符    obj.value = obj.value.replace(/^\./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'); //只能输出两个小数    if(obj.value.indexOf(".")< 0 && obj.value !=""){//以上曾经过滤,此处管制的是如果没有小数点,首位不能为相似于 01、02的金额             if(obj.value.substr(0,1) == '0' && obj.value.length == 2){                     obj.value= parseFloat(obj.value);                 }      }}