JavaScript中判斷整數(shù)的多種方法總結(jié)
之前記錄過JavaScript中判斷為數(shù)字類型的多種方式,這篇看看如何判斷為整數(shù)類型(Integer)。
JavaScript中不區(qū)分整數(shù)和浮點(diǎn)數(shù),所有數(shù)字內(nèi)部都采用64位浮點(diǎn)格式表示,和Java的double類型一樣。但實(shí)際操作中比如數(shù)組索引、位操作則是基于32位整數(shù)。
方式一、使用取余運(yùn)算符判斷
任何整數(shù)都會(huì)被1整除,即余數(shù)是0。利用這個(gè)規(guī)則來判斷是否是整數(shù)。
function isInteger(obj) {
return obj%1 === 0
}
isInteger(3) // true
isInteger(3.3) // false
以上輸出可以看出這個(gè)函數(shù)挺好用,但對(duì)于字符串和某些特殊值顯得力不從心
isInteger('') // true
isInteger('3') // true
isInteger(true) // true
isInteger([]) // true
對(duì)于空字符串、字符串類型數(shù)字、布爾true、空數(shù)組都返回了true,真是難以接受。對(duì)這些類型的內(nèi)部轉(zhuǎn)換細(xì)節(jié)感興趣的請(qǐng)參考:JavaScript中奇葩的假值
因此,需要先判斷下對(duì)象是否是數(shù)字,比如加一個(gè)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ù)取整后還是等于自己。利用這個(gè)特性來判斷是否是整數(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
這個(gè)直接把字符串,true,[]屏蔽了,代碼量比上一個(gè)函數(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
很不錯(cuò),但也有一個(gè)缺點(diǎn)
isInteger(1000000000000000000000) // false
竟然返回了false,沒天理啊。原因是parseInt在解析整數(shù)之前強(qiáng)迫將第一個(gè)參數(shù)解析成字符串。這種方法將數(shù)字轉(zhuǎn)換成整型不是一個(gè)好的選擇。
四、通過位運(yù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
這個(gè)函數(shù)很不錯(cuò),效率還很高。但有個(gè)缺陷,上文提到過,位運(yùn)算只能處理32位以內(nèi)的數(shù)字,對(duì)于超過32位的無能為力,如
isInteger(Math.pow(2, 32)) // 32位以上的數(shù)字返回false了
當(dāng)然,多數(shù)時(shí)候我們不會(huì)用到那么大的數(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)支持。
相關(guān)文章
Javascript call及apply應(yīng)用場(chǎng)景及實(shí)例
這篇文章主要介紹了Javascript call及apply應(yīng)用場(chǎng)景及實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-08-08
JavaScript實(shí)現(xiàn)數(shù)組降維詳解
大家都知道將多維數(shù)組(尤其是二維數(shù)組)轉(zhuǎn)化為一維數(shù)組是業(yè)務(wù)開發(fā)中的常用邏輯,除了使用樸素的循環(huán)轉(zhuǎn)換以外,我們還可以利用Javascript的語(yǔ)言特性和數(shù)據(jù)結(jié)構(gòu)的思想實(shí)現(xiàn)更為簡(jiǎn)潔優(yōu)雅的轉(zhuǎn)換。下面跟著小編一起來學(xué)習(xí)學(xué)習(xí)關(guān)于JavaScript如何實(shí)現(xiàn)數(shù)組降維吧。2017-01-01
js函數(shù)與php函數(shù)的區(qū)別實(shí)例淺析
這篇文章主要介紹了js函數(shù)與php函數(shù)的區(qū)別,以實(shí)例形式較為簡(jiǎn)單的分析了js函數(shù)與php函數(shù)語(yǔ)法及應(yīng)用上的不同點(diǎn),具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-01-01
webpack是如何實(shí)現(xiàn)模塊化加載的方法
這篇文章主要介紹了webpack是如何實(shí)現(xiàn)模塊化加載的方法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11
js+html5實(shí)現(xiàn)頁(yè)面可刷新的倒計(jì)時(shí)效果
這篇文章主要為大家詳細(xì)介紹了js+html5實(shí)現(xiàn)頁(yè)面可刷新的倒計(jì)時(shí)效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-07-07
兼容ie ff div 層 打開+關(guān)閉+ 拖動(dòng)+遮罩+移動(dòng)+動(dòng)畫改變高寬
div層 打開+關(guān)閉+ 拖動(dòng)+遮罩+移動(dòng)+動(dòng)畫改變高寬的實(shí)例js代碼2008-07-07
微信小程序?qū)崿F(xiàn)環(huán)形進(jìn)度條
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)環(huán)形進(jìn)度條,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06

