首页 > 编程 > JavaScript > 正文

JS保留小数点(四舍五入、四舍六入)实现思路及实例

2019-11-20 22:46:18
字体:
来源:转载
供稿:网友
复制代码 代码如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
<head>
<title>floatDecimal.html</title>
<meta http-equiv="keywords" content="keyword1,keyword2,keyword3">
<meta http-equiv="description" content="this is my page">
<meta http-equiv="content-type" content="text/html; charset=gb2312">
<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);
}
//四舍五入
document.writeln("保留2位小数:" + toDecimal(3.14159267) + '<br/>');
document.writeln("强制保留2位小数:" + toDecimal2(3.14159267) + '<br/>');
document.writeln("保留2位小数:" + toDecimal(3.14559267) + '<br/>');
document.writeln("强制保留2位小数:" + toDecimal2(3.15159267) + '<br/>');
document.writeln("保留2位小数:" + fomatFloat(3.14559267, 2) + '<br/>');
document.writeln("保留1位小数:" + fomatFloat(3.15159267, 1) + '<br/>');
//五舍六入
document.writeln("保留2位小数:" + 1000.003.toFixed(2) + '<br/>');
document.writeln("保留1位小数:" + 1000.08.toFixed(1) + '<br/>');
document.writeln("保留1位小数:" + 1000.04.toFixed(1) + '<br/>');
document.writeln("保留1位小数:" + 1000.05.toFixed(1) + '<br/>');
//科学计数
document.writeln(3.1415.toExponential(2) + '<br/>');
document.writeln(3.1455.toExponential(2) + '<br/>');
document.writeln(3.1445.toExponential(2) + '<br/>');
document.writeln(3.1465.toExponential(2) + '<br/>');
document.writeln(3.1665.toExponential(1) + '<br/>');
//精确到n位,不含n位
document.writeln("精确到小数点第2位" + 3.1415.toPrecision(2) + '<br/>');
document.writeln("精确到小数点第3位" + 3.1465.toPrecision(3) + '<br/>');
document.writeln("精确到小数点第2位" + 3.1415.toPrecision(2) + '<br/>');
document.writeln("精确到小数点第2位" + 3.1455.toPrecision(2) + '<br/>');
document.writeln("精确到小数点第5位" + 3.141592679287.toPrecision(5) + '<br/>');
</script>
</head>
<body>
This is my HTML page. <br>
</body>
</html>


javascript四舍五入保留两位小数

复制代码 代码如下:

function count(){
   //alert("count");
   var size=~~(document.getElementById("size").value);
   var value=0;
   for(var i=0;i<size;i++){
    var val=1*(document.getElementById("afterAdjScor"+i).value);
    if(null!=val){
     value =Math.round((1*(value+val))*100)/100;
    }
   }
   if(isNaN(value)){
    value="输入必须为数字类型";
   }
   document.getElementById("total").value=value;
  }

说明:~~XX:字符串转int
      1*XX:字符串转float
      Math.round((1*(value+val))*100)/100:四舍五入

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表