javascript让文本框只能输入数字, 带数字类型和限制最大值功能.

 网上看到过很多javascript验证数字输入的方法, 自己也写了个算是总结吧. 如有算法和逻辑上的问题, 欢迎大家拍砖啊. IE6.0下测试通过.

转载请注明出自: http://blog.csdn.net/pisces_fri/

<SCRIPT language="javascript" type="text/javascript"> /** * @author: pisces.fri */

 

// ============================================================================= // validationNumber methods

/** * Validate the input text as a number * * @param object ID of the input control object * @param string Number type ('int', 'u_int', 'float' or 'u_float') * @param number Max number allowed to input * @param object ID of the error message control object * * @return null */ function validationNumber(hndID, numType, maxNum, hndMsgID) {  var keyCode = window.event.keyCode;  var ch = String.fromCharCode(keyCode);  var value = '';  var retCode = 0;  var oNumVerify=null;

 //屏蔽回车键  if (keyCode==13)  {   window.event.keyCode = 0;   return null;  }

 if (hndID != undefined)  {   value += hndID.value+ch;  }  else  {   window.event.keyCode = keyCode;   return null;  }

 oNumVerify = new isNumeric(value);  if (oNumVerify.isNumber)  {   numType = numType.toString().toLowerCase();   switch(numType)   {    case 'u_int':  //正整数     if ((oNumVerify.isMinus==false) && (oNumVerify.isDecimal==false))     {      retCode = keyCode;     }     break;    case 'u_float':  //正实数     if (oNumVerify.isMinus==false)     {      retCode = keyCode;     }     break;    case 'int':   //整数     if (oNumVerify.isDecimal==false)     {      retCode = keyCode;     }     break;    case 'float':  //实数     retCode = keyCode;     break;    default:     retCode = 0;   }

  //判断输入的数字是否超过设置的最大值   if ((maxNum!=undefined) && (maxNum.constructor==Number) && (oNumVerify.value > maxNum))   {    retCode = 0;    if (hndMsgID != undefined)    {     hndMsgID.innerHTML = '<SPAN style="color:#EE3333">值不能大于'+maxNum+'</SPAN>';    }   }  }

 oNumVerify = null;  window.event.keyCode = retCode;  return null; }

function isNumeric(verifyNum) {  var re = /^([-]{0,1})([0-9]*)([/.]{0,1})([0-9]*)$/g;  this.isNumber = false;  this.isMinus = false;  this.isDecimal = false;  this.value = verifyNum;

 verifyNum = verifyNum.toString();

 if (re.test(verifyNum))  {   this.isNumber = true;   re.exec(verifyNum);

  //判断 '-' 符号   if (RegExp.$1=='-')   {    this.isMinus = true;   }

  //判断 '.' 符号   if (RegExp.$3=='.')   {    this.isDecimal = true;    verifyNum += '0';   }

  try   {    this.value = parseFloat(verifyNum);   }   catch(e)   {    this.value = 0;   }  }

 return; } </SCRIPT> 使用方法:<br/> <INPUT type="text" name="txtYear" id="txt_Year" size="4" οnkeypress="javascript:validationNumber(this, 'float', 2006, txtYearMsg);" style="text-align:right;ime-mode:disabled;" maxlength="4"/>年&nbsp;&nbsp;<SPAN id="txtYearMsg"></SPAN>

 

IE6.0下测试通过.

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值