一、使用取余運算符判斷
任何整數都會被1整除,即余數是0。利用這個規則來判斷是否是整數。
function isInteger(obj) { return obj%1 === 0}isInteger(3) // trueisInteger(3.3) // false 以上輸出可以看出這個函數挺好用,但對于字符串和某些特殊值顯得力不從心
isInteger('') // trueisInteger('3') // trueisInteger(true) // trueisInteger([]) // true對于空字符串、字符串類型數字、布爾true、空數組都返回了true,真是難以接受。對這些類型的內部轉換細節感興趣的請參考:
因此,需要先 判斷下對象是否是數字 ,比如加一個typeof
function isInteger(obj) { return typeof obj === 'number' && obj%1 === 0}isInteger('') // falseisInteger('3') // falseisInteger(true) // falseisInteger([]) // false嗯,這樣比較完美了。
二、使用Math.round、Math.ceil、Math.floor判斷
整數取整后還是等于自己。利用這個特性來判斷是否是整數,Math.floor示例,如下
function isInteger(obj) { return Math.floor(obj) === obj}isInteger(3) // trueisInteger(3.3) // falseisInteger('') // falseisInteger('3') // falseisInteger(true) // falseisInteger([]) // false這個直接把字符串,true,[]屏蔽了,代碼量比上一個函數還少。
三、通過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在解析整數之前強迫將第一個參數解析成字符串。這種方法將數字轉換成整型不是一個好的選擇。
四、通過位運算判斷
function isInteger(obj) { return (obj | 0) === obj}isInteger(3) // trueisInteger(3.3) // falseisInteger('') // falseisInteger('3') // falseisInteger(true) // falseisInteger([]) // false這個函數很不錯,效率還很高。但有個缺陷,上文提到過,位運算只能處理32位以內的數字,對于超過32位的無能為力,如
isInteger(Math.pow(2, 32)) // 32位以上的數字返回false了
當然,多數時候我們不會用到那么大的數字。
五、ES6提供了Number.isInteger
Number.isInteger(3) // trueNumber.isInteger(3.1) // falseNumber.isInteger('') // falseNumber.isInteger('3') // falseNumber.isInteger(true) // falseNumber.isInteger([]) // false目前,最新的 Firefox 和Chrome已經支持。
六、js 輸入int類型數字后自動在后面加.00
var getFloatStr = function (num) { num += ''; num = num.replace(/[^0-9|/.]/g, ''); //清除字符串中的非數字非.字符 if (/^0+/) //清除字符串開頭的0 num = num.replace(/^0+/, ''); if (!//./.test(num)) //為整數字符串在末尾添加.00 num += '.00'; if (/^/./.test(num)) //字符以.開頭時,在開頭添加0 num = '0' + num; num += '00'; //在字符串末尾補零 num = num.match(//d+/./d{2}/)[0]; return num; };如若vue 全局使用 在 main.js
Vue.prototype.getFloatStr = function(num) { num += ''; num = num.replace(/[^0-9|/.]/g, ''); //清除字符串中的非數字非.字符 if (/^0+/) //清除字符串開頭的0 num = num.replace(/^0+/, ''); if (!//./.test(num)) //為整數字符串在末尾添加.00 num += '.00'; if (/^/./.test(num)) //字符以.開頭時,在開頭添加0 num = '0' + num; num += '00'; //在字符串末尾補零 num = num.match(//d+/./d{2}/)[0]; return num;}方法有很多種 例如:
js將小數轉為保留兩位小數(保留0.00和不保留)
function toDecimal2(x) { var f = Math.round(x * 100) / 100; var s = f.toString(); var rs = s.indexOf('.'); if (rs < 0) { rs = s.length; s += '.'; } while (s.length <= rs + 2) { s += '0'; } return s;}//保留2位小數,如:2,還會保留2 不會補0function toDecimal2NoZero(x) { var f = Math.round(x * 100) / 100; var s = f.toString(); return s;}總結
以上所述是小編給大家介紹的JavaScript中判斷為整數的多種方式及保留兩位小數,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對武林網網站的支持!如果你覺得本文對你有幫助,歡迎轉載,煩請注明出處,謝謝!
新聞熱點
疑難解答