當前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
JavaScript中判断为整数的多种方式
生活随笔
收集整理的這篇文章主要介紹了
JavaScript中判断为整数的多种方式
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
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位的無能為力,如
| 1 | 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已經支持。
總結
以上是生活随笔為你收集整理的JavaScript中判断为整数的多种方式的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: javascript中两个等号和三个等号
- 下一篇: jQuery取得select选择的文本与