Rumah  >  Artikel  >  hujung hadapan web  >  js 判断值是否为数字

js 判断值是否为数字

藏色散人
藏色散人asal
2021-03-01 15:00:0839722semak imbas

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

js 判断值是否为数字

本文操作环境:windows7系统,DELL G3电脑

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()详解【推荐:js基础教程

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

对于空数组和只有一个数值成员的数组,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(val).toString() == "NaN"

Atas ialah kandungan terperinci js 判断值是否为数字. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Artikel sebelumnya:js如何判断字符串是否为空Artikel seterusnya:卸载node的命令