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

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

高洛峰
高洛峰原創
2016-11-02 10:23:571070瀏覽

我們知道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]'
  }

這次,如果傳入的是非數字(NaN或可轉成NaN的值)就回傳false了

 isNumber不錯了,但還有一個等價的,用isFinite來判斷

 

複製代碼代碼如下:

function isNumber(obj) {
    return typeof obj === 'number' && !isNaN(obj)
}
isNumber(1)   // true
isNumber(1.2) // true
isNumber(NaN) // false
isNumber( parseInt('a') ) // false

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

 

複製代碼代碼如下:

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

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

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

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

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

 

複製程式碼如下:

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

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