這篇看看如何判斷爲整數類型(Integer),JavaScript中不區分整數和浮點數,全部數字內部都採用64位浮點格式表示,和Java的double類型同樣。但實際操做中好比數組索引、位操做則是基於32位整數。數組
任何整數都會被1整除,即餘數是0。利用這個規則來判斷是不是整數。函數
function isInteger(obj) { return obj%1 === 0 } isInteger(3) // true isInteger(3.3) // false
以上輸出能夠看出這個函數挺好用,但對於字符串和某些特殊值顯得力不從心code
isInteger('') // true isInteger('3') // true isInteger(true) // true isInteger([]) // true
對於空字符串、字符串類型數字、布爾true、空數組都返回了true,真是難以接受。對這些類型的內部轉換細節感興趣的請參考:JavaScript中奇葩的假值 所以,須要先判斷下對象是不是數字,好比加一個typeof對象
function isInteger(obj) { return typeof obj === 'number' && obj%1 === 0 } isInteger('') // false isInteger('3') // false isInteger(true) // false isInteger([]) // false
嗯,這樣比較完美了。索引
整數取整後仍是等於本身。利用這個特性來判斷是不是整數,Math.floor示例,以下ip
function isInteger(obj) { return Math.floor(obj) === obj } isInteger(3) // true isInteger(3.3) // false isInteger('') // false isInteger('3') // false isInteger(true) // false isInteger([]) // false
這個直接把字符串,true,[]屏蔽了,代碼量比上一個函數還少。字符串
function isInteger(obj) { return parseInt(obj, 10) === obj } isInteger(3) // true isInteger(3.3) // false isInteger('') // false isInteger('3') // false isInteger(true) // false isInteger([]) // false 很不錯,但也有一個缺點 isInteger(1000000000000000000000) // false
居然返回了false,沒天理啊。緣由是parseInt在解析整數以前強迫將第一個參數解析成字符串。這種方法將數字轉換成整型不是一個好的選擇。io
function isInteger(obj) { return (obj | 0) === obj } isInteger(3) // true isInteger(3.3) // false isInteger('') // false isInteger('3') // false isInteger(true) // false isInteger([]) // false
這個函數很不錯,效率還很高。但有個缺陷,上文提到過,位運算只能處理32位之內的數字,對於超過32位的無能爲力,如 複製代碼 代碼以下:function
isInteger(Math.pow(2, 32)) // 32位以上的數字返回false了
固然,多數時候咱們不會用到那麼大的數字。效率
Number.isInteger(3) // true Number.isInteger(3.1) // false Number.isInteger('') // false Number.isInteger('3') // false Number.isInteger(true) // false Number.isInteger([]) // false
目前,最新的Firefox和Chrome已經支持。