五種js判斷是否為整數(shù)類型方式
這篇看看如何判斷為整數(shù)類型(Integer),JavaScript中不區(qū)分整數(shù)和浮點數(shù),所有數(shù)字內(nèi)部都采用64位浮點格式表示,和Java的double類型一樣。但實際操作中比如數(shù)組索引、位操作則是基于32位整數(shù)。
方式一、使用取余運算符判斷
任何整數(shù)都會被1整除,即余數(shù)是0。利用這個規(guī)則來判斷是否是整數(shù)。
function isInteger(obj) {
return obj%1 === 0
}
isInteger(3) // true
isInteger(3.3) // false
以上輸出可以看出這個函數(shù)挺好用,但對于字符串和某些特殊值顯得力不從心
isInteger('') // true
isInteger('3') // true
isInteger(true) // true
isInteger([]) // true
對于空字符串、字符串類型數(shù)字、布爾true、空數(shù)組都返回了true,真是難以接受。對這些類型的內(nèi)部轉(zhuǎn)換細節(jié)感興趣的請參考:JavaScript中奇葩的假值
因此,需要先判斷下對象是否是數(shù)字,比如加一個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判斷
整數(shù)取整后還是等于自己。利用這個特性來判斷是否是整數(shù),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,[]屏蔽了,代碼量比上一個函數(shù)還少。
方式三、通過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在解析整數(shù)之前強迫將第一個參數(shù)解析成字符串。這種方法將數(shù)字轉(zhuǎn)換成整型不是一個好的選擇。
方式四、通過位運算判斷
function isInteger(obj) {
return (obj | 0) === obj
}
isInteger(3) // true
isInteger(3.3) // false
isInteger('') // false
isInteger('3') // false
isInteger(true) // false
isInteger([]) // false
這個函數(shù)很不錯,效率還很高。但有個缺陷,上文提到過,位運算只能處理32位以內(nèi)的數(shù)字,對于超過32位的無能為力,如
當然,多數(shù)時候我們不會用到那么大的數(shù)字。
方式五、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已經(jīng)支持。
以上就是判斷是否為整數(shù)類型的五種方式,這五種方式各有優(yōu)缺點,大家可以進行仔細比較,選擇最優(yōu)的進行使用。
- js判斷undefined類型,undefined,null, 的區(qū)別詳細解析
- 客戶端js判斷文件類型和文件大小即限制上傳大小
- js判斷數(shù)據(jù)類型如判斷是否為數(shù)組是否為字符串等等
- JS通過分析userAgent屬性來判斷瀏覽器的類型及版本
- JavaScript判斷輸入是否為數(shù)字類型的方法總結(jié)
- 通過JS判斷聯(lián)網(wǎng)類型和連接狀態(tài)的實現(xiàn)代碼
- js 判斷各種數(shù)據(jù)類型的簡單方法(推薦)
- 利用js判斷瀏覽器類型(是否為IE,Firefox,Opera瀏覽器)
- JS如何判斷瀏覽器類型和詳細區(qū)分IE各版本瀏覽器
- javascript中如何判斷類型匯總
相關(guān)文章
javascript簡單實現(xiàn)表格行間隔顯示顏色并高亮顯示
表格行間隔顯示顏色并實現(xiàn)高亮顯示,這種效果大家都有見到過吧,下面就為大家詳細介紹下,需要的朋友可不要錯過2013-11-11
Three.js后期處理效果(發(fā)光描邊OutlinePass)
這篇文章主要給大家介紹了關(guān)于Three.js后期處理效果(發(fā)光描邊OutlinePass)的相關(guān)資料,Three js 開發(fā)的一些知識整理,方便后期遇到類似的問題,能夠及時查閱使用,需要的朋友可以參考下2024-01-01
JavaScript獲取XML數(shù)據(jù)附示例截圖
這篇文章主要介紹了JavaScript獲取XML數(shù)據(jù)的方法,需要的朋友可以參考下2014-03-03
js(JavaScript)實現(xiàn)TAB標簽切換效果的簡單實例
本篇文章主要是對js(JavaScript)實現(xiàn)TAB標簽切換效果的簡單實例進行了介紹,需要的朋友可以過來參考下,希望對大家有所幫助2014-02-02
Locate a File Using a File Open Dialog Box
Locate a File Using a File Open Dialog Box...2007-06-06

