您好,登錄后才能下訂單哦!
這篇文章主要介紹javascript如何驗證是否是數字類型,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!
javascript驗證是否是數字類型的方法:1、使用isNaN()函數判斷值是否是數字;2、使用正則表達式判斷;3、使用parseFloat()函數判斷。
本文操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。
javascript 驗證是否是數字類型?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()詳解
參考鏈接: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()函數
/** * 驗證數據 是數字:返回true;不是數字:返回false **/ function Number(val) { if (parseFloat(val).toString() == "NaN") { return false; } else { return true; } } //isNaN(val)不能判斷空串或一個空格 //如果是一個空串、空格或null,而isNaN是做為數字0進行處理的,而parseInt與parseFloat是返回一個錯誤消息,這個isNaN檢查不嚴密而導致的。
以上是“javascript如何驗證是否是數字類型”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。