這篇看看如何判斷為整數(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) // trueisInteger(3.3) // false 以上輸出可以看出這個函數(shù)挺好用,但對于字符串和某些特殊值顯得力不從心
isInteger('') // trueisInteger('3') // trueisInteger(true) // trueisInteger([]) // true對于空字符串、字符串類型數(shù)字、布爾true、空數(shù)組都返回了true,真是難以接受。對這些類型的內(nèi)部轉(zhuǎn)換細節(jié)感興趣的請參考:JavaScript中奇葩的假值
因此,需要先判斷下對象是否是數(shù)字,比如加一個typeof
function isInteger(obj) { return typeof obj === 'number' && obj%1 === 0}isInteger('') // falseisInteger('3') // falseisInteger(true) // falseisInteger([]) // false嗯,這樣比較完美了。
方式二、使用Math.round、Math.ceil、Math.floor判斷
整數(shù)取整后還是等于自己。利用這個特性來判斷是否是整數(shù),Math.floor示例,如下
function isInteger(obj) { return Math.floor(obj) === obj}isInteger(3) // trueisInteger(3.3) // falseisInteger('') // falseisInteger('3') // falseisInteger(true) // falseisInteger([]) // false這個直接把字符串,true,[]屏蔽了,代碼量比上一個函數(shù)還少。
方式三、通過parseInt判斷
function isInteger(obj) { return parseInt(obj, 10) === obj}isInteger(3) // trueisInteger(3.3) // falseisInteger('') // falseisInteger('3') // falseisInteger(true) // falseisInteger([]) // false很不錯,但也有一個缺點
isInteger(1000000000000000000000) // false
竟然返回了false,沒天理啊。原因是parseInt在解析整數(shù)之前強迫將第一個參數(shù)解析成字符串。這種方法將數(shù)字轉(zhuǎn)換成整型不是一個好的選擇。
方式四、通過位運算判斷
function isInteger(obj) { return (obj | 0) === obj}isInteger(3) // trueisInteger(3.3) // falseisInteger('') // falseisInteger('3') // falseisInteger(true) // falseisInteger([]) // false這個函數(shù)很不錯,效率還很高。但有個缺陷,上文提到過,位運算只能處理32位以內(nèi)的數(shù)字,對于超過32位的無能為力,如
Number.isInteger(3) // trueNumber.isInteger(3.1) // falseNumber.isInteger('') // falseNumber.isInteger('3') // falseNumber.isInteger(true) // falseNumber.isInteger([]) // false目前,最新的Firefox和Chrome已經(jīng)支持。
以上就是判斷是否為整數(shù)類型的五種方式,這五種方式各有優(yōu)缺點,大家可以進行仔細比較,選擇最優(yōu)的進行使用。
新聞熱點
疑難解答