JavaScript中判斷整數(shù)的多種方法總結(jié)
之前記錄過(guò)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ī)則來(lái)判斷是否是整數(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è)特性來(lái)判斷是否是整數(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ù)還少。
三、通過(guò)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,沒(méi)天理啊。原因是parseInt在解析整數(shù)之前強(qiáng)迫將第一個(gè)參數(shù)解析成字符串。這種方法將數(shù)字轉(zhuǎn)換成整型不是一個(gè)好的選擇。
四、通過(guò)位運(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è)缺陷,上文提到過(guò),位運(yùn)算只能處理32位以內(nèi)的數(shù)字,對(duì)于超過(guò)32位的無(wú)能為力,如
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 彈出窗體點(diǎn)擊按鈕返回選擇數(shù)據(jù)的實(shí)現(xiàn)
這兩天一直想實(shí)現(xiàn)這個(gè),以前做做個(gè)Demo,但是不知道跑哪去了。于是今天在網(wǎng)上找了些資料再自己動(dòng)手搞定。廢話不多說(shuō)。直接進(jìn)入主題啦。2010-04-04JavaScript實(shí)現(xiàn)為input與textarea自定義hover,focus效果的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)為input與textarea自定義hover,focus效果的方法,可實(shí)現(xiàn)根據(jù)鼠標(biāo)事件動(dòng)態(tài)改變input與textarea樣式的功能,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08JavaScript的Number對(duì)象的toString()方法
toString()方法可以把Number對(duì)象轉(zhuǎn)換成字符串,并返回此字符串,本文給大家介紹JavaScript的Number對(duì)象的toString()方法,對(duì)javascript對(duì)象方法相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2015-12-12js防刷新的倒計(jì)時(shí)代碼 js倒計(jì)時(shí)代碼
這篇文章主要為大家詳細(xì)介紹了js防刷新的倒計(jì)時(shí)代碼,js倒計(jì)時(shí)的實(shí)現(xiàn)代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-09-09移動(dòng)端H5開(kāi)發(fā) Turn.js實(shí)現(xiàn)很棒的翻書(shū)效果
這篇文章主要為大家詳細(xì)介紹了Turn.js實(shí)現(xiàn)很棒的翻書(shū)效果,對(duì)Turn.js翻書(shū)效果的實(shí)現(xiàn)進(jìn)行總結(jié),感興趣的小伙伴們可以參考一下2016-06-06Next.js使用getServerSideProps進(jìn)行服務(wù)器端渲染demo
這篇文章主要為大家介紹了Next.js使用getServerSideProps進(jìn)行服務(wù)器端渲染demo,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-12-12JavaScript實(shí)現(xiàn)獲取dom中class的方法
這篇文章主要介紹了JavaScript實(shí)現(xiàn)獲取dom中class的方法,涉及javascript操作dom節(jié)點(diǎn)的使用技巧,需要的朋友可以參考下2015-02-02