這篇看看如何判斷為整數型別(Integer),JavaScript中不區分整數和浮點數,所有數字內部都採用64位元浮點格式表示,和Java的double型別一樣。但實際操作中例如數組索引、位元操作則是基於32位元整數。
方式一、使用取餘運算子判斷
任何整數都會被1整除,即餘數是0。利用這個規則來判斷是否為整數。
function isInteger(obj) { return obj%1 === 0 } isInteger(3) // true isInteger(3.3) // false
以上輸出可以看出這個函數挺好用,但對於字串和某些特殊值顯得力不從心
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.round、Math.ceil、Math.floor判斷
整數取整後還是等於自己。利用這個特性來判斷是否為整數,Math.floor範例,如下
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,[]封鎖了,程式碼量比上一個函數還少。
方式三、透過parseInt判斷
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在解析整數之前強迫將第一個參數解析成字串。這種方法將數字轉換成整數不是一個好的選擇。
方式四、透過位元運算判斷
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位的無能為力,如
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已經支援。
以上就是判斷是否為整數類型的五種方式,這五種方式各有優缺點,大家可以進行仔細比較,選擇最優的進行使用。