首頁 >web前端 >js教程 >javascript怎麼判斷值是否為整數

javascript怎麼判斷值是否為整數

青灯夜游
青灯夜游原創
2021-04-26 16:16:313112瀏覽

判斷方法:1、使用「值%1===0」語句;2、使用「Math.floor(值)===值」語句;3、使用「parseInt(值,10) ===值」語句;4、使用「(值|0)===值」語句;5、使用「Number.isInteger(值)」語句。

javascript怎麼判斷值是否為整數

本教學操作環境:windows7系統、javascript1.8.5版、Dell G3電腦。

JavaScript中不區分整數和浮點數,所有數字內部都以64位元浮點格式表示,和Java的double型別一樣。但實際操作中例如數組索引、位元操作則是基於32位元整數。那麼如何判斷是否為整數類型(Integer)?

方式一、使用取餘運算子判斷

任何整數都會被1整除,也就是餘數是0。利用這個規則來判斷是否為整數。

function isInteger(obj) {
 return obj%1 === 0
}
isInteger(3) // true
isInteger(3.3) // false 

以上輸出可以看出這個函數挺好用,但對於字串和某些特殊值顯得力不從心

isInteger('') // true
isInteger('3') // true
isInteger(true) // true
isInteger([]) // true

對於空字串、字串型別數字、布林true、空數組都回傳了true,真是難以接受。對這些類型的內部轉換細節感興趣的請參考:JavaScript中奇葩的假值

因此,需要先判斷下物件是否是數字,例如加一個typeof

function isInteger(obj) {
 return typeof obj === 'number' && obj%1 === 0
}
isInteger('') // false
isInteger('3') // false
isInteger(true) // false
isInteger([]) // false

嗯,這樣比較完美了。

方式二、使用Math.floor判斷

整數取整後還是等於自己。利用這個特性來判斷是否是整數,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,[]屏蔽了,程式碼量比上一個函數還少。

方式三、透過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在解析整數之前強迫將第一個參數解析成字串。這種方法將數字轉換成整數不是一個好的選擇。 

方式四、透過位元運算判斷

function isInteger(obj) {
 return (obj | 0) === obj
}
isInteger(3) // true
isInteger(3.3) // false
isInteger('') // false
isInteger('3') // false
isInteger(true) // false
isInteger([]) // false

這個函數很不錯,效率還很高。但有個缺陷,上文提到過,位運算只能處理32位以內的數字,對於超過32位的無能為力,如

isInteger(Math.pow(2, 32)) // 32位以上的数字返回false了

#當然,多數時候我們不會用到那麼大的數字。

方式五、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已經支援。

說明:這五種方式各有優缺點,大家可以進行仔細比較,選擇最優的進行使用。

【推薦學習:javascript高階教學

#

以上是javascript怎麼判斷值是否為整數的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn