js判斷值是否為數字的方法:1、使用isNaN()函數判斷值是否為數字;2、使用正規表示式判斷值是否為數字;3、使用parseFloat()函數判斷值是否為數字。
本文操作環境: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"
以上是js 判斷值是否為數字的詳細內容。更多資訊請關注PHP中文網其他相關文章!