溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

怎么在javascript怎么判斷一個(gè)數(shù)據(jù)是否為數(shù)字

發(fā)布時(shí)間:2021-04-07 15:29:44 來(lái)源:億速云 閱讀:344 作者:Leah 欄目:web開(kāi)發(fā)

怎么在javascript怎么判斷一個(gè)數(shù)據(jù)是否為數(shù)字?相信很多沒(méi)有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問(wèn)題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問(wèn)題。

javascript判斷是否數(shù)字的方法:1、使用isNaN()函數(shù),語(yǔ)法格式“isNaN(value)”,可以檢查其參數(shù)value是否為非數(shù)字值;2、使用test()函數(shù)配合正則表達(dá)式來(lái)判斷;3、利用parseFloat()函數(shù)來(lái)判斷。

1.使用isNaN()函數(shù)

isNaN()的缺點(diǎn)就在于 null、空格以及空串會(huì)被按照0來(lái)處理

NaN: Not a Number

/**
*判斷是否是數(shù)字
*
**/

function isRealNum(val){
    // isNaN()函數(shù) 把空串 空格 以及NUll 按照0來(lái)處理 所以先去除,
    
  if(val === "" || val ==null){
        return false;
  }
   if(!isNaN(val)){    
  //對(duì)于空數(shù)組和只有一個(gè)數(shù)值成員的數(shù)組或全是數(shù)字組成的字符串,isNaN返回false,例如:'123'、[]、[2]、['123'],isNaN返回false,
   //所以如果不需要val包含這些特殊情況,則這個(gè)判斷改寫(xiě)為if(!isNaN(val) && typeof val === 'number' )
    return true; 
  }

 else{ 
    return false; 
  } 
}

isNaN()函數(shù)來(lái)判斷一個(gè)值是數(shù)字的最正確的方法就是:

// true:數(shù)值型的,false:非數(shù)值型
  function myIsNaN(value) {
    return typeof value === 'number' && !isNaN(value);
  }

isNaN()詳解

對(duì)于空數(shù)組和只有一個(gè)數(shù)值成員的數(shù)組,isNaN返回false。

isNaN([]) // false
isNaN([123]) // false
isNaN(['123']) // false

上面代碼之所以返回false,原因是這些數(shù)組能被Number函數(shù)轉(zhuǎn)成數(shù)值,請(qǐng)參見(jiàn)《數(shù)據(jù)類型轉(zhuǎn)換》一章。

因此,使用isNaN之前,最好判斷一下數(shù)據(jù)類型。

function myIsNaN(value) {
  return typeof value === 'number' && !isNaN(value);
}

2.使用正則表達(dá)式 

(1)、校驗(yàn)只要是數(shù)字(包含正負(fù)整數(shù),0以及正負(fù)浮點(diǎn)數(shù))就返回true

/**
* 校驗(yàn)只要是數(shù)字(包含正負(fù)整數(shù),0以及正負(fù)浮點(diǎn)數(shù))就返回true
**/

function isNumber(val){

    var regPos = /^\d+(\.\d+)?$/; //非負(fù)浮點(diǎn)數(shù)
    var regNeg = /^(-(([0-9]+\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\.[0-9]+)|([0-9]*[1-9][0-9]*)))$/; //負(fù)浮點(diǎn)數(shù)
    if(regPos.test(val) && regNeg.test(val)){
        return true;
    }else{
        return false;
    }

}

(2)、校驗(yàn)正負(fù)正數(shù)就返回true

/**
* 校驗(yàn)正負(fù)正數(shù)就返回true
**/

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

常用正則:

"^\\d+$"             //非負(fù)整數(shù)(正整數(shù) + 0) 
"^[0-9]*[1-9][0-9]*$"     //正整數(shù) 
"^((-\\d+)|(0+))$"       //非正整數(shù)(負(fù)整數(shù) + 0) 
"^-[0-9]*[1-9][0-9]*$"    //負(fù)整數(shù) 
"^-?\\d+$"            //整數(shù) 
"^\\d+("            //非負(fù)浮點(diǎn)數(shù)(正浮點(diǎn)數(shù) + 0) 
"^(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*))$"    //正浮點(diǎn)數(shù) 
"^((-\\d+("           //非正浮點(diǎn)數(shù)(負(fù)浮點(diǎn)數(shù) + 0) 
"^(-(([0-9]+\\.[0-9]*[1-9][0-9]*)|([0-9]*[1-9][0-9]*\\.[0-9]+)|([0-9]*[1-9][0-9]*)))$"    //負(fù)浮點(diǎn)數(shù) 
"^(-?\\d+)("         //浮點(diǎn)數(shù)

3.使用parseFloat()函數(shù)

/**
* 驗(yàn)證數(shù)據(jù) 是數(shù)字:返回true;不是數(shù)字:返回false
**/

function Number(val) {
  if (parseFloat(val).toString() == "NaN") {
    
    return false;
  } else {
    return true;
  }
}

//isNaN(val)不能判斷空串或一個(gè)空格
//如果是一個(gè)空串、空格或null,而isNaN是做為數(shù)字0進(jìn)行處理的,而parseInt與parseFloat是返回一個(gè)錯(cuò)誤消息,這個(gè)isNaN檢查不嚴(yán)密而導(dǎo)致的。

看完上述內(nèi)容,你們掌握怎么在javascript怎么判斷一個(gè)數(shù)據(jù)是否為數(shù)字的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI