首頁 > web前端 > js教程 > javascript怎麼判斷值是否是數字

javascript怎麼判斷值是否是數字

青灯夜游
發布: 2023-01-05 16:11:34
原創
2383 人瀏覽過

方法:1、test()配合正規表示式;2、parseFloat()函數,語法「parseFloat(值).toString()=="NaN"」;3、isNaN()函數,語法「typeof 值==='number'&&!isNaN(值)」。

javascript怎麼判斷值是否是數字

本教學操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。

方法1:使用test() 正規表示式

校驗只要是數字(包含正負整數,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:使用parseFloat()函數

/**
* 验证数据 是数字:返回true;不是数字:返回false
**/
function Number(val) {
  if (parseFloat(val).toString() == "NaN") {
    
    return false;
  } else {
    return true;
  }
}
登入後複製

方法3:使用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);
}
登入後複製

【推薦學習:javascript進階教學

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

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板