五種js判斷是否為整數(轉)


五種js判斷是否為整數類型方式

作者:snandy 

這篇文章主要介紹了五種JavaScript判斷是否為整數類型方式,需要的朋友可以參考下
 

這篇看看如何判斷為整數類型(Integer),JavaScript中不區分整數和浮點數,所有數字內部都采用64位浮點格式表示,和Java的double類型一樣。但實際操作中比如數組索引、位操作則是基於32位整數。
方式一、使用取余運算符判斷
任何整數都會被1整除,即余數是0。利用這個規則來判斷是否是整數。

?
1
2
3
4
5
function isInteger(obj) {
  return obj%1 === 0
}
isInteger(3) // true
isInteger(3.3) // false 

以上輸出可以看出這個函數挺好用,但對於字符串和某些特殊值顯得力不從心

?
1
2
3
4
isInteger( '' ) // true
isInteger( '3' ) // true
isInteger( true ) // true
isInteger([]) // true

對於空字符串、字符串類型數字、布爾true、空數組都返回了true,真是難以接受。對這些類型的內部轉換細節感興趣的請參考:JavaScript中奇葩的假值
因此,需要先判斷下對象是否是數字,比如加一個typeof

?
1
2
3
4
5
6
7
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示例,如下

?
1
2
3
4
5
6
7
8
9
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判斷

?
1
2
3
4
5
6
7
8
9
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

很不錯,但也有一個缺點

?
1
isInteger(1000000000000000000000) // false

竟然返回了false,沒天理啊。原因是parseInt在解析整數之前強迫將第一個參數解析成字符串。這種方法將數字轉換成整型不是一個好的選擇。 
方式四、通過位運算判斷

?
1
2
3
4
5
6
7
8
9
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

 

?
1
2
3
4
5
6
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已經支持。

以上就是判斷是否為整數類型的五種方式,這五種方式各有優缺點,大家可以進行仔細比較,選擇最優的進行使用。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM