溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

JavaScript中使用取余運(yùn)算符判斷整數(shù)的方法

發(fā)布時(shí)間:2021-03-06 15:44:33 來源:億速云 閱讀:889 作者:小新 欄目:web開發(fā)

小編給大家分享一下JavaScript中使用取余運(yùn)算符判斷整數(shù)的方法,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

一、使用取余運(yùn)算符判斷

任何整數(shù)都會(huì)被1整除,即余數(shù)是0。利用這個(gè)規(guī)則來判斷是否是整數(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è)特性來判斷是否是整數(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ù)還少。

三、通過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è)好的選擇。

四、通過位運(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è)缺陷,上文提到過,位運(yùn)算只能處理32位以內(nèi)的數(shù)字,對(duì)于超過32位的無能為力,如

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)支持。

六、js 輸入int類型數(shù)字后自動(dòng)在后面加.00

var getFloatStr = function (num) {
 num += '';
 num = num.replace(/[^0-9|\.]/g, ''); //清除字符串中的非數(shù)字非.字符
 if (/^0+/) //清除字符串開頭的0
  num = num.replace(/^0+/, '');
 if (!/\./.test(num)) //為整數(shù)字符串在末尾添加.00
  num += '.00';
 if (/^\./.test(num)) //字符以.開頭時(shí),在開頭添加0
  num = '0' + num;
 num += '00'; //在字符串末尾補(bǔ)零
 num = num.match(/\d+\.\d{2}/)[0];
 return num;
 };

如若vue 全局使用 在 main.js

Vue.prototype.getFloatStr = function(num) {
 num += '';
 num = num.replace(/[^0-9|\.]/g, ''); //清除字符串中的非數(shù)字非.字符

 if (/^0+/) //清除字符串開頭的0
 num = num.replace(/^0+/, '');
 if (!/\./.test(num)) //為整數(shù)字符串在末尾添加.00
 num += '.00';
 if (/^\./.test(num)) //字符以.開頭時(shí),在開頭添加0
 num = '0' + num;
 num += '00'; //在字符串末尾補(bǔ)零
 num = num.match(/\d+\.\d{2}/)[0];
 return num;
}

方法有很多種 例如:

js將小數(shù)轉(zhuǎn)為保留兩位小數(shù)(保留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位小數(shù),如:2,還會(huì)保留2 不會(huì)補(bǔ)0
function toDecimal2NoZero(x) {
 var f = Math.round(x * 100) / 100;
 var s = f.toString();
 return s;
}

看完了這篇文章,相信你對(duì)“JavaScript中使用取余運(yùn)算符判斷整數(shù)的方法”有了一定的了解,如果想了解更多相關(guān)知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

js
AI