五种js判断是否为整数类型方式
2019獨(dú)角獸企業(yè)重金招聘Python工程師標(biāo)準(zhǔn)>>>
這篇看看如何判斷為整數(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,沒天理啊。原因是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ú)能為力,如 復(fù)制代碼 代碼如下:
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)支持。
轉(zhuǎn)載于:https://my.oschina.net/jallenkwong/blog/1797007
總結(jié)
以上是生活随笔為你收集整理的五种js判断是否为整数类型方式的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: mongod副本集的安装配置
- 下一篇: Vue 教程第十七 篇—— Vuex 之