js取float型小數(shù)點(diǎn)后兩位數(shù)的方法
js取小數(shù)點(diǎn)后兩位四種方法
http://www.dbjr.com.cn/article/154898.htm
以下我們將為大家介紹 JavaScript 保留兩位小數(shù)的實(shí)現(xiàn)方法:
四舍五入
以下處理結(jié)果會(huì)四舍五入:
var num =2.446242342; num = num.toFixed(2); // 輸出結(jié)果為 2.45
不四舍五入
以下處理結(jié)果不會(huì)四舍五入:
第一種,先把小數(shù)邊整數(shù):
Math.floor(15.7784514000 * 100) / 100 // 輸出結(jié)果為 15.77
第二種,當(dāng)作字符串,使用正則匹配:
Number(15.7784514000.toString().match(/^\d+(?:\.\d{0,2})?/)) // 輸出結(jié)果為 15.77,不能用于整數(shù)如 10 必須寫(xiě)為10.0000
注意:如果是負(fù)數(shù),請(qǐng)先轉(zhuǎn)換為正數(shù)再計(jì)算,最后轉(zhuǎn)回負(fù)數(shù)
javascript保留兩位小數(shù)的實(shí)例:
<script type="text/javascript"> //保留兩位小數(shù) //功能:將浮點(diǎn)數(shù)四舍五入,取小數(shù)點(diǎn)后2位 function toDecimal(x) { var f = parseFloat(x); if (isNaN(f)) { return; } f = Math.round(x*100)/100; return f; } //制保留2位小數(shù),如:2,會(huì)在2后面補(bǔ)上00.即2.00 function toDecimal2(x) { var f = parseFloat(x); if (isNaN(f)) { return false; } 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; } function fomatFloat(src,pos){ return Math.round(src*Math.pow(10, pos))/Math.pow(10, pos); } //四舍五入 alert("保留2位小數(shù):" + toDecimal(3.14159267)); alert("強(qiáng)制保留2位小數(shù):" + toDecimal2(3.14159267)); alert("保留2位小數(shù):" + toDecimal(3.14559267)); alert("強(qiáng)制保留2位小數(shù):" + toDecimal2(3.15159267)); alert("保留2位小數(shù):" + fomatFloat(3.14559267, 2)); alert("保留1位小數(shù):" + fomatFloat(3.15159267, 1)); //五舍六入 alert("保留2位小數(shù):" + 1000.003.toFixed(2)); alert("保留1位小數(shù):" + 1000.08.toFixed(1)); alert("保留1位小數(shù):" + 1000.04.toFixed(1)); alert("保留1位小數(shù):" + 1000.05.toFixed(1)); //科學(xué)計(jì)數(shù) alert(3.1415.toExponential(2)); alert(3.1455.toExponential(2)); alert(3.1445.toExponential(2)); alert(3.1465.toExponential(2)); alert(3.1665.toExponential(1)); //精確到n位,不含n位 alert("精確到小數(shù)點(diǎn)第2位" + 3.1415.toPrecision(2)); alert("精確到小數(shù)點(diǎn)第3位" + 3.1465.toPrecision(3)); alert("精確到小數(shù)點(diǎn)第2位" + 3.1415.toPrecision(2)); alert("精確到小數(shù)點(diǎn)第2位" + 3.1455.toPrecision(2)); alert("精確到小數(shù)點(diǎn)第5位" + 3.141592679287.toPrecision(5)); </script>
用Javascript取float型小數(shù)點(diǎn)后兩位,例22.127456取成22.13,如何做?
1.丟棄小數(shù)部分,保留整數(shù)部分
parseInt(5/2)
2.向上取整,有小數(shù)就整數(shù)部分加1
Math.ceil(5/2)
3,四舍五入.
Math.round(5/2)
4,向下取整
Math.floor(5/2)
另類(lèi)的方法
1. 最笨的辦法
function get()
{
var s = 22.127456 + "";
var str = s.substring(0,s.indexOf(".") + 3);
alert(str);
}
2. 正則表達(dá)式效果不錯(cuò)
<script type="text/javascript">
onload = function(){
var a = "23.456322";
var aNew;
var re = /([0-9]+.[0-9]{2})[0-9]*/;
aNew = a.replace(re,"$1");
alert(aNew);
}
</script>
3. 他就比較聰明了.....
<script>
var num=22.127456;
alert( Math.round(num*100)/100);
</script>
4.會(huì)用新鮮東西的朋友....... 但是需要 IE5.5+才支持。
5.js保留2位小數(shù)(強(qiáng)制)
對(duì)于小數(shù)點(diǎn)位數(shù)大于2位的,用上面的函數(shù)沒(méi)問(wèn)題,但是如果小于2位的,比如:changeTwoDecimal(3.1),將返回3.1,如果你一定需要3.10這樣的格式,那么需要下面的這個(gè)函數(shù):
function changeTwoDecimal_f(x) {
var f_x = parseFloat(x);
if (isNaN(f_x)) {
alert('function:changeTwoDecimal->parameter error');
return false;
}
var f_x = Math.round(x * 100) / 100;
var s_x = f_x.toString();
var pos_decimal = s_x.indexOf('.');
if (pos_decimal < 0) {
pos_decimal = s_x.length;
s_x += '.';
}
while (s_x.length <= pos_decimal + 2) {
s_x += '0';
}
return s_x;
}
功能:將浮點(diǎn)數(shù)四舍五入,取小數(shù)點(diǎn)后2位,如果不足2位則補(bǔ)0,
這個(gè)函數(shù)返回的是字符串的格式用法:changeTwoDecimal(3.1415926)返回3.14 changeTwoDecimal(3.1)返回3.10
相關(guān)文章
JS實(shí)現(xiàn)圖片高亮展示效果實(shí)例
這篇文章主要介紹了JS實(shí)現(xiàn)圖片高亮展示效果的方法,實(shí)例分析了JavaScript響應(yīng)鼠標(biāo)事件動(dòng)態(tài)操作頁(yè)面元素樣式的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11javascript鼠標(biāo)跟隨運(yùn)動(dòng)3種效果(眼球效果,蘋(píng)果菜單,方向跟隨)
在很多網(wǎng)站上能看到圖片跟隨鼠標(biāo)移動(dòng)的JS特效,其實(shí)做法很簡(jiǎn)單,本文就介紹了很多javascript鼠標(biāo)跟隨運(yùn)動(dòng),在這里與大家分享下。2016-10-10原生js canvas實(shí)現(xiàn)鼠標(biāo)跟隨效果
這篇文章主要為大家詳細(xì)介紹了原生js canvas實(shí)現(xiàn)鼠標(biāo)跟隨效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08用Golang運(yùn)行JavaScript的實(shí)現(xiàn)示例
這篇文章主要介紹了用Golang運(yùn)行JavaScript的實(shí)現(xiàn)示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-11-11JavaScript+node實(shí)現(xiàn)三級(jí)聯(lián)動(dòng)菜單
這篇文章主要為大家詳細(xì)介紹了JavaScript+node實(shí)現(xiàn)三級(jí)聯(lián)動(dòng)菜單,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07微信小程序?qū)崙?zhàn)之雙人五子棋游戲是實(shí)現(xiàn)
這篇文章主要為大家詳細(xì)介紹了如何利用微信小程序?qū)崿F(xiàn)雙人五子棋游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-05-05