首頁 >web前端 >js教程 >js如何判斷值是否數字

js如何判斷值是否數字

coldplay.xixi
coldplay.xixi原創
2021-02-19 10:43:148752瀏覽

js判斷值是否數字的方法:1、使用【isNaN()】函數,程式碼為【return typeof value === 'number' && !isNaN(value)】;2、使用正規表示式;3、使用【parseFloat()】函數。

js如何判斷值是否數字

本教學操作環境:windows7系統、javascript1.8.5版,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()詳解

對於空數組和只有一個數值成員的數組,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()函數

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

相關免費學習推薦:javascript影片教學

#

以上是js如何判斷值是否數字的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn