温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

怎么用JS判断值是否是数字

发布时间:2022-09-27 09:34:23 来源:亿速云 阅读:104 作者:iii 栏目:开发技术

这篇文章主要讲解了“怎么用JS判断值是否是数字”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么用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()详解

对于空数组和只有一个数值成员的数组,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检查不严密而导致的。

感谢各位的阅读,以上就是“怎么用JS判断值是否是数字”的内容了,经过本文的学习后,相信大家对怎么用JS判断值是否是数字这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

js
AI