千家信息网

javascript如何验证是否是数字类型

发表于:2025-02-02 作者:千家信息网编辑
千家信息网最后更新 2025年02月02日,这篇文章主要介绍javascript如何验证是否是数字类型,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!javascript验证是否是数字类型的方法:1、使用isNaN()函数
千家信息网最后更新 2025年02月02日javascript如何验证是否是数字类型

这篇文章主要介绍javascript如何验证是否是数字类型,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!

javascript验证是否是数字类型的方法:1、使用isNaN()函数判断值是否是数字;2、使用正则表达式判断;3、使用parseFloat()函数判断。

本文操作环境:windows7系统、javascript1.8.5版、Dell G3电脑。

javascript 验证是否是数字类型?JS判断值是否是数字

1.使用isNaN()函数

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

NaN: Not a Number

/***判断是否是数字***/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()详解

参考链接:https://wangdoc.com/javascript/types/number.html#isnan

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

isNaN([]) // falseisNaN([123]) // falseisNaN(['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()函数

/*** 验证数据 是数字:返回true;不是数字:返回false**/function Number(val) {  if (parseFloat(val).toString() == "NaN") {        return false;  } else {    return true;  }}//isNaN(val)不能判断空串或一个空格//如果是一个空串、空格或null,而isNaN是做为数字0进行处理的,而parseInt与parseFloat是返回一个错误消息,这个isNaN检查不严密而导致的。

以上是"javascript如何验证是否是数字类型"这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!

0