首頁  >  文章  >  web前端  >  JavaScript中判斷整字型別最簡潔的實作方法

JavaScript中判斷整字型別最簡潔的實作方法

PHPz
PHPz原創
2016-05-16 16:31:551431瀏覽

這篇文章主要介紹了JavaScript中判斷整字類型最簡潔的實作方法,本章給出多個判斷整數的方法,最後總結出一個最短、最簡潔的實作方法,需要的朋友可以參考下。

我們知道JavaScript提供了typeof運算符,因此最容易想到的是用typeof來判斷是否是number類型。

function isNumber(obj) {
    return typeof obj === 'number'
}

這個函數對於整數和浮點數都沒有問題,但對於NaN值也回傳true這讓人感到不爽,畢竟用isNumber判斷通過後誰也不會用NaN去做算術運算。

那改進一下,用Object.prototype.toString試試。

function isNumber(obj) {
    return Object.prototype.toString.call(obj) === '[object Number]'
}

和typeof判斷一樣,對於NaN也回傳true,程式碼量還大了,這不是想要的結果。 toString.call方式判斷數組(Array)可行,數字則力不從心了。

再改進下,NaN值用isNaN函數來對付。

function isNumber(obj) {
    return typeof obj === 'number' && !isNaN(obj)
}

這次,如果傳入的是非數字(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)    
}

到現在,最短代碼的數字判斷是此文提到的第三個使用isNaN函數的。下面隆重推出世界上最短的數字判斷代碼

function isNumber(obj) {
    return obj === +obj
}

對於整數,浮點數回傳true,對於NaN或可轉成NaN的值傳回false。

沒看懂是嗎? 咕~~(╯﹏╰)

園友說這還不是全世界最短判斷數字代碼,參數obj可以改成一個字元的。 (⊙o⊙)你是對的。

舉一反三,類似的利用JS動態語言特性(運算子運算時內部自動型別轉換)最短的判斷還有。

// 判断字符串
function isString(obj) {
    return obj === obj+''
}
// 判断布尔类型
function isBoolean(obj) {
    return obj === !!obj
}

以上就是本章的全部內容,更多相關教學請訪問JavaScript影片教學

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn