這篇文章主要介紹了JavaScript中判斷整字類型最簡潔的實現(xiàn)方法,本文給出多個判斷整數(shù)的方法,
最后總結出一個最短、最簡潔的實現(xiàn)方法,需要的朋友可以參考下
我們知道JavaScript提供了typeof運算符,因此最容易想到的是用typeof來判斷是否是number類型。
function isNumber(obj) { return typeof obj === ’number’ }
這個函數(shù)對于整數(shù)和浮點數(shù)都沒有問題,但對于NaN值也返回true這讓人感到不爽,
畢竟用isNumber判斷通過后誰也不會用NaN去做算術運算。
那改進一下,用Object.prototype.toString試試。
function isNumber(obj) { return Object.prototype.toString.call(obj) === ’[object Number]’ }
和typeof判斷一樣,對于NaN也返回true,代碼量還大了,這不是想要的結果。
toString.call方式判斷js數(shù)組(Array)可行,數(shù)字則力不從心了。
再改進下,NaN值用isNaN函數(shù)來對付。
function isNumber(obj) { return typeof obj === ’number’ && !isNaN(obj) }
這次,如果傳入的是非數(shù)字(NaN或者可轉成NaN的值)就返回false了
function isNumber(obj) { return typeof obj === ’number’ && !isNaN(obj) } isNumber(1) // true isNumber(1.2) // true isNumber(NaN) // false isNumber( parseInt(’a’) ) // false
嗯,這個isNumber不錯了,但還有一個等價的,用isFinite來判斷
function isNumber(obj) { return typeof obj === ’number’ && isFinite(obj) }
到現(xiàn)在,最短代碼的數(shù)字判斷是此文提到的第三個使用isNaN函數(shù)的。
下面隆重推出世界上最短的數(shù)字判斷網(wǎng)頁代碼
function isNumber(obj) { return obj === +obj }
對于整數(shù),浮點數(shù)返回true,對于NaN或可轉成NaN的值返回false。
沒看懂是嗎? 咕~~(╯﹏╰)
園友說這還不是世界上最短判斷數(shù)字代碼,參數(shù)obj可以改成一個字符的。(⊙o⊙)你是對的。
舉一反三,類似的利用JS動態(tài)語言特性(運算符運算時內部自動類型轉換)最短的判斷還有。
// 判斷字符串 function isString(obj) { return obj === obj+’’ } // 判斷布爾類型 function isBoolean(obj) { return obj === !!obj }
【 微信掃一掃 】