html验证用户名不能有数字,javascript如何验证值是否是数字?

javascript如何验证值是否是数字?下面本篇文章给大家介绍一下。有一定的参考价值,有需要的朋友可以参考一下,希望对大家有所帮助。

a531f0a2bf3ff046992c246360a11ec0.png

js验证是否为数字,最简单的方法:使用isNaN函数;最完整最精确的方法:(正则表达式)。

方法1:使用isNaN()函数

isNaN()的缺点就在于 null、空格以及空串会被按照0来处理/**

*判断是否是数字

*

**/

function isRealNum(val){

// isNaN()函数 把空串 空格 以及NUll 按照0来处理 所以先去除,

if(val === "" || val ==null){

return false;

}

if(!isNaN(val)){

//对于空数组和只有一个数值成员的数组或全是数字组成的字符串,isNaN返回false,例如:'123'、[]、[2]、['123'],isNaN返回false,

//所以如果不需要val包含这些特殊情况,则这个判断改写为if(!isNaN(val) && typeof val === 'number' )

return true;

}

else{

return false;

}

}

isNaN()函数来判断一个值是数字的最正确的方法就是:// true:数值型的,false:非数值型

function myIsNaN(value) {

return typeof value === 'number' && !isNaN(value);

}

说明:

对于空数组和只有一个数值成员的数组,isNaN返回false。isNaN([]) // false

isNaN([123]) // false

isNaN(['123']) // false

上面代码之所以返回false,原因是这些数组能被Number函数转成数值,请参见《数据类型转换》一章。

因此,使用isNaN之前,最好判断一下数据类型。function myIsNaN(value) {

return typeof value === 'number' && !isNaN(value);

}

方法2:使用正则表达式

1)、校验只要是数字(包含正负整数,0以及正负浮点数)就返回true/**

* 校验只要是数字(包含正负整数,0以及正负浮点数)就返回true

**/

function isNumber(val){

var regPos = /^\d+(\.\d+)?$/; //非负浮点数

var regNeg = /^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$/; //负浮点数

if(regPos.test(val) && regNeg.test(val)){

return true;

}else{

return false;

}

}

2)、 校验正负正数就返回true/**

* 校验正负正数就返回true

**/

function isIntNum(val){

var regPos = / ^\d+$/; // 非负整数

var regNeg = /^\-[1-9][0-9]*$/; // 负整数

if(regPos.test(val) && regNeg.test(val)){

return true;

}else{

return false;

}

}

方法3:使用parseFloat()函数

parseFloat() 函数可解析一个字符串,并返回一个浮点数。

该函数指定字符串中的首个字符是否是数字。如果是,则对字符串进行解析,直到到达数字的末端为止,然后以数字返回该数字,而不是作为字符串。/**

* 验证数据 是数字:返回true;不是数字:返回false

**/

function Number(val) {

if (parseFloat(val).toString() == "NaN") {

return false;

} else {

return true;

}

}

//isNaN(val)不能判断空串或一个空格

//如果是一个空串、空格或null,而isNaN是做为数字0进行处理的,而parseInt与parseFloat是返回一个错误消息,这个isNaN检查不严密而导致的。

更多web前端自学相关知识,请查阅 HTML中文网 !!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值