實(shí)現(xiàn)js保留小數(shù)點(diǎn)后N位的代碼
在JS中,一般實(shí)現(xiàn)保留小數(shù)點(diǎn)后N位的話,都是利用toFixed函數(shù)
<script language="javascript">
document.write("<h1>JS保留兩位小數(shù)例子</h1><br>");
var a=2.1512131231231321;
document.write("原來(lái)的值:"+a+"<br>");
document.write("兩位小數(shù)點(diǎn):"+a.toFixed(2)+"<br>四位小數(shù)點(diǎn)"+a.toFixed(4));
</script>
四舍五入的轉(zhuǎn)換函數(shù),如下:
function round(v,e){
var t=1;
for(;e>0;t*=10,e--);
for(;e<0;t/=10,e++);
return Math.round(v*t)/t;
}
參數(shù)里的:
v表示要轉(zhuǎn)換的值
e表示要保留的位數(shù)
函數(shù)里的兩個(gè)for,這個(gè)是重點(diǎn)了,
第一個(gè)for針對(duì)小數(shù)點(diǎn)右邊的情況,也就是保留小數(shù)點(diǎn)右邊多少位;
第二個(gè)for針對(duì)小數(shù)點(diǎn)左邊的情況,也就是保留小數(shù)點(diǎn)左邊多少位。
for的作用,就是計(jì)算t的值,也就是v應(yīng)該放大或者縮小多少倍的倍數(shù)(倍數(shù)=t)。
for這里利用到了for里的兩個(gè)特性,條件判斷和計(jì)數(shù)器累計(jì)(循環(huán)),
當(dāng)e滿足條件時(shí)for繼續(xù),并且e每次累加(e的每次累加,就是給for制造不滿足循環(huán)的條件)的同時(shí),也計(jì)算t的值。
最后利用了原生的round方法來(lái)計(jì)算被放大/縮小后的v的結(jié)果,然后把結(jié)果放大/縮小到正確的倍數(shù)
下面各種保留二位數(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>
以上就是全部代碼了,是不是超級(jí)簡(jiǎn)單,希望對(duì)大家能有所幫助
- JavaScript中保留小數(shù)點(diǎn)后N位方法總結(jié)
- Js保留小數(shù)點(diǎn)的4種效果實(shí)現(xiàn)代碼分享
- js保留小數(shù)點(diǎn)后幾位的寫法
- js浮點(diǎn)數(shù)保留兩位小數(shù)點(diǎn)示例代碼(四舍五入)
- js驗(yàn)證整數(shù)加保留小數(shù)點(diǎn)的簡(jiǎn)單實(shí)例
- JS格式化數(shù)字保留兩位小數(shù)點(diǎn)示例代碼
- javascript中RegExp保留小數(shù)點(diǎn)后幾位數(shù)的方法分享
- JS保留小數(shù)點(diǎn)(四舍五入、四舍六入)實(shí)現(xiàn)思路及實(shí)例
- 在 JavaScript 中保留小數(shù)點(diǎn)后兩位的方法
相關(guān)文章
easyui-edatagrid.js實(shí)現(xiàn)回車鍵結(jié)束編輯功能的實(shí)例
下面小編就為大家?guī)?lái)一篇easyui-edatagrid.js實(shí)現(xiàn)回車鍵結(jié)束編輯功能的實(shí)例。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-04-04JavaScript實(shí)現(xiàn)簡(jiǎn)易的天數(shù)計(jì)算器實(shí)例【附demo源碼下載】
這篇文章主要介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)易的天數(shù)計(jì)算器,結(jié)合實(shí)例形式分析了javascript日期與時(shí)間計(jì)算的相關(guān)技巧,并附帶demo源碼供讀者下載參考,需要的朋友可以參考下2017-01-01js實(shí)現(xiàn)跨域的幾種方法匯總(圖片ping、JSONP和CORS)
平時(shí)用慣了jQuery.ajax之類的方法,卻時(shí)常忽略了它背后的實(shí)現(xiàn),本文是學(xué)習(xí)了AJAX基礎(chǔ)及幾種跨域解決方案之后的一些收獲。2015-10-10頁(yè)面中實(shí)現(xiàn)setInterval和setTimeout效果示例詳解
這篇文章主要為大家介紹了不使用setTimeout和setInterval在頁(yè)面中實(shí)現(xiàn)setInterval和setTimeout效果示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-09-09bootstrap實(shí)現(xiàn)tab選項(xiàng)卡切換
這篇文章主要為大家詳細(xì)介紹了bootstrap實(shí)現(xiàn)tab選項(xiàng)卡切換,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-08-08解決layui數(shù)據(jù)表格table的橫向滾動(dòng)條顯示問(wèn)題
今天小編就為大家分享一篇解決layui數(shù)據(jù)表格table的橫向滾動(dòng)條顯示問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09