如何检查文本框中输入的内容是否为整数?我使用了NAN函数,但它也接受十进制值。
我该怎么做?有没有内置方法?
如何检查文本框中输入的内容是否为整数?我使用了NAN函数,但它也接受十进制值。
我该怎么做?有没有内置方法?
假设文本框由变量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
}
Number("")
返回0,而 Math.floor(value) == value
返回true。如果将 value 留为空字符串,则也返回true。 - RobG正则表达式将是一种方法:
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),但是在这里我重用了 JavaScript 中的 .trim() 不在 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);
}
test
,但仍然很奇怪。此外,它没有考虑开头或结尾的空格。 - Brian Donovan// 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;
}
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
如果你要寻找整数或小数,可以选择:
function IsNumeric(input)
{
return (input - 0) == input && input.length > 0;
}
... && input.trim().length > 0
。 - The Bitmanvar num = document.getElementById("myField").value;
if(/^\d+$/.test(num)) {
// is an int
}
表单数据始终是文本。我的建议是将其解析为整数并与原始值进行比较:
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
科学计数法和千位分隔符都不被支持。如果这是一个问题,你需要使用其他方法 ;)
更新:我想要明确的是,这只是其中一种可能的方法,而不是唯一的真理。如果您需要对数据进行数学运算,那么这种方法是有意义的,因此您必须获取数字变量。