文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么在javascript怎么判断一个数据是否为数字

2023-06-14 11:08

关注

怎么在javascript怎么判断一个数据是否为数字?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。

javascript判断是否数字的方法:1、使用isNaN()函数,语法格式“isNaN(value)”,可以检查其参数value是否为非数字值;2、使用test()函数配合正则表达式来判断;3、利用parseFloat()函数来判断。

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

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

function isIntNum(val){    var regPos = / ^\d+$/; // 非负整数     var regNeg = /^\-[1-9][0-9]*$/; // 负整数    if(regPos.test(val) && regNeg.test(val)){        return true;    }else{        return false;    } }

常用正则:

"^\\d+$"             //非负整数(正整数 + 0) "^[0-9]*[1-9][0-9]*$"     //正整数 "^((-\\d+)|(0+))$"       //非正整数(负整数 + 0) "^-[0-9]*[1-9][0-9]*$"    //负整数 "^-?\\d+$"            //整数 "^\\d+("            //非负浮点数(正浮点数 + 0) "^(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*))$"    //正浮点数 "^((-\\d+("           //非正浮点数(负浮点数 + 0) "^(-(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*)))$"    //负浮点数 "^(-?\\d+)("         //浮点数

3.使用parseFloat()函数

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

看完上述内容,你们掌握怎么在javascript怎么判断一个数据是否为数字的方法了吗?如果还想学到更多技能或想了解更多相关内容,欢迎关注编程网行业资讯频道,感谢各位的阅读!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     807人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     351人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     314人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     433人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     221人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯