1. 程式人生 > >js判斷是否為整數型別(5種方式)

js判斷是否為整數型別(5種方式)

方式一、使用取餘運算子判斷

任何整數都會被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

方式三、通過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

原因是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位的無能為力
isInteger(Math.pow(2, 32)) // 32位以上的數字返回false了

方式五、ES6提供了Number.isInteger

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已經支援。