在javascript中检查textfield的值是否为整数

时间:2010-12-28 06:38:11

标签: javascript validation

我如何检查在文本框中输入的文本是否为整数?我使用NAN函数,但它也接受十进制值。

我该怎么做?有内置方法吗?

7 个答案:

答案 0 :(得分:16)

假设文本字段由变量intfield引用,那么您可以这样检查:

var value = Number(intfield.value);
if (Math.floor(value) == value) {
  // value is an integer, do something based on that
} else {
  // value is not an integer, show some validation error
}

答案 1 :(得分:1)

正则表达式是一种方式:

var re = /^-?\d\d*$/
alert(re.test(strNumber)); // leading or trailing spaces are also invalid here

包含更新的完整示例:

http://rgagnon.com/jsdetails/js-0063.html

function validateInteger( strValue ) {
/************************************************
DESCRIPTION: Validates that a string contains only
    valid integer number.

PARAMETERS:
   strValue - String to be tested for validity

RETURNS:
   True if valid, otherwise false.
**************************************************/
  var objRegExp  = /(^-?\d\d*$)/;  

  //check for integer characters
  return objRegExp.test(strValue);
}

更新以处理空白 - 在验证中可能不允许这样做,但无论如何它在这里: 可以继续使用我给出的链接中的代码(leftTrim / rightTrim),但在这里我重用.trim() in JavaScript not working in IE中的trim

function ignoreLeadingAndtrailingWhitespace( strValue ) {
  return strValue.length>0?validateInteger( strValue.trim() ):false;
}

if(typeof String.prototype.trim !== 'function') { 
  String.prototype.trim = function() {
    return this.replace(/^\s+|\s+$/g, ''); 
  }
}


function validateInteger( strValue ) {
/************************************************
DESCRIPTION: Validates that a string contains only
    valid integer number.

PARAMETERS:
   strValue - String to be tested for validity

RETURNS:
   True if valid, otherwise false.
**************************************************/
  var objRegExp  = /(^-?\d\d*$)/;

  //check for integer characters
  return objRegExp.test(strValue);
}

答案 2 :(得分:1)

// validate if the input is numeric and between min and max digits
function validateNumberSize(inputtxt, min, max)
{
    var numbers = /^[0-9]+$/;
    if(inputtxt.match(numbers))
    {
        if(inputtxt.length >= min && inputtxt.length <= max)
        {
            return true;
        }
    }
    return false;
}

答案 3 :(得分:0)

var num = document.getElementById("myField").value;
if(/^\d+$/.test(num)) {
    // is an int
}

答案 4 :(得分:0)

表单数据始终是文本。我的建议是你将它解析为整数并将其与原始数据进行比较:

var sampleData = ["not a number", "0", "10", "3.14", "-12", "-0.34", "2e10", "34foo", "foo34"];
var integers = [], notIntegers = [];
for(var i=0, len=sampleData.length; i<len; i++){
    var original = sampleData[i];
    var parsed = parseInt(original, 10);
    if( !isNaN(parsed) && original==parsed ){
        integers.push(parsed);
    }else{
        notIntegers.push(original);
    }
}
alert("Integers: " + integers.join(", ") + "\nNot integers: " + notIntegers.join(", "));

这表明:

Integers: 0, 10, -12
Not integers: not a number, 3.14, -0.34, 2e10, 34foo, foo34

不支持科学记数法,也不支持千位​​分词。如果这是一个问题,你需要一些不同的东西;)

更新:我想明确指出,这只是可能的方法之一,而不是唯一的真理。如果你需要对数据进行数学运算,这种方法是有意义的,所以你必须得到一个数值变量。

答案 5 :(得分:0)

如果您要查找整数或小数,可以选择:

function IsNumeric(input)
{
   return (input - 0) == input && input.length > 0;
}

答案 6 :(得分:0)

最好使用正则表达式,如下所示:

function isInteger(str) {
    var r = /^-?[0-9]*[1-9][0-9]*$/;
    return r.test(str);
}

只是一个测试演示:

> function isInteger(str) {
...     var r = /^-?[0-9]*[1-9][0-9]*$/;
...     return r.test(str);
... }
> isInteger("-123")
true
> isInteger("a123")
false
> isInteger("123.4")
false