js判断输入是否为数字

JavaScript017

js判断输入是否为数字,第1张

如何验证文本框中的内容是否为数字,本文提供了三种方法,希望对大家的学习有所启发。

在某些情况下可能需要让文本框中的内容只能够输入数字,例如手机号码或者邮编之类的,下面简单介绍一下如何实现此功能。

下面是验证数字的正则表达式:

用js判断文本框输入的内容是否是数字:

如何判断输入文本框是值是否是数字?

单纯的判断是否是正整数,可使用char.IsDigh(string,int index)和IsNumber(string,int index)函数

但是,出现负数或者小数的时候,以上方法失效,则,使用自定义功能函数

问题分析:

在JavaScript脚本语言中判断一个字符串中是否即包含数字亦包含字母,可以使用正则(RegExp对象)的方式,如果仅仅只是做判断,要求返回true或者false的话,那么使用RegExp对象的test方法即可。

举例如下:

//定义字符串

var str1 = '123' //第一个字符串,仅有数字。

var str2 = 'abc' //第二个字符串,仅有字母。

var str3 = 'a1b2c3' //第三个字符串,既有数字亦有字母。

//定义验证规则,由于字符串数字和字母的顺序可能不同。

//也有可能字母和数字中间还包含了其他字符。故将验证规则分开定义。

var regNumber = /\d+/ //验证0-9的任意数字最少出现1次。

var regString = /[a-zA-Z]+/ //验证大小写26个字母任意字母最少出现1次。

//验证第一个字符串

if (regNumber.test(str1) && regString.test(str1)) {

    console.log('str1:验证成功')

}else{

    console.log('str1:验证失败')

}

//验证第二个字符串

if (regNumber.test(str2) && regString.test(str2)) {

    console.log('str2:验证成功')

}else{

    console.log('str2:验证失败')

}

//验证第三个字符串

if (regNumber.test(str3) && regString.test(str3)) {

    console.log('str3:验证成功')

}else{

    console.log('str3:验证失败')

}

运行结果:

总结:

由于第一个字符串仅有数字,第二个字符串仅有字母,都不符合数字和字母都必须存在的需求,所以执行结果是“验证失败”,而第三个字符串,既包含字母亦包含数字,所以执行结果是“验证成功”。

根据规则,NaN与任何东西比较,返回都是false。你需要调用isNaN函数

if(isNaN(x)) {

document.write("输入错误")

}else {

document.write("输入正确")

}