实现js保留小数点后N位的代码

前端技术 2023/09/07 JavaScript

在JS中,一般实现保留小数点后N位的话,都是利用toFixed函数

复制代码 代码如下:

<script language=\"javascript\">
document.write(\"<h1>JS保留两位小数例子</h1><br>\");
var a=2.1512131231231321;
document.write(\"原来的值:\"+a+\"<br>\");
document.write(\"两位小数点:\"+a.toFixed(2)+\"<br>四位小数点\"+a.toFixed(4));
</script>

四舍五入的转换函数,如下:

复制代码 代码如下:

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;
}

参数里的:

v表示要转换的值

e表示要保留的位数

函数里的两个for,这个是重点了,

第一个for针对小数点右边的情况,也就是保留小数点右边多少位;

第二个for针对小数点左边的情况,也就是保留小数点左边多少位。

for的作用,就是计算t的值,也就是v应该放大或者缩小多少倍的倍数(倍数=t)。

for这里利用到了for里的两个特性,条件判断和计数器累计(循环),

当e满足条件时for继续,并且e每次累加(e的每次累加,就是给for制造不满足循环的条件)的同时,也计算t的值。

最后利用了原生的round方法来计算被放大/缩小后的v的结果,然后把结果放大/缩小到正确的倍数

下面各种保留二位数实例

复制代码 代码如下:

<script type=\"text/javascript\">
//保留两位小数
//功能:将浮点数四舍五入,取小数点后2位
function toDecimal(x) {
var f = parseFloat(x);
if (isNaN(f)) {
return;
}
f = Math.round(x*100)/100;
return f;
}
//制保留2位小数,如:2,会在2后面补上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位小数:\" + toDecimal(3.14159267));
alert(\"强制保留2位小数:\" + toDecimal2(3.14159267));
alert(\"保留2位小数:\" + toDecimal(3.14559267));
alert(\"强制保留2位小数:\" + toDecimal2(3.15159267));
alert(\"保留2位小数:\" + fomatFloat(3.14559267, 2));
alert(\"保留1位小数:\" + fomatFloat(3.15159267, 1));
//五舍六入
alert(\"保留2位小数:\" + 1000.003.toFixed(2));
alert(\"保留1位小数:\" + 1000.08.toFixed(1));
alert(\"保留1位小数:\" + 1000.04.toFixed(1));
alert(\"保留1位小数:\" + 1000.05.toFixed(1));
//科学计数
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(\"精确到小数点第2位\" + 3.1415.toPrecision(2));
alert(\"精确到小数点第3位\" + 3.1465.toPrecision(3));
alert(\"精确到小数点第2位\" + 3.1415.toPrecision(2));
alert(\"精确到小数点第2位\" + 3.1455.toPrecision(2));
alert(\"精确到小数点第5位\" + 3.141592679287.toPrecision(5));
</script>

以上就是全部代码了,是不是超级简单,希望对大家能有所帮助

本文地址:https://www.stayed.cn/item/18196

转载请注明出处。

本站部分内容来源于网络,如侵犯到您的权益,请 联系我

我的博客

人生若只如初见,何事秋风悲画扇。