美文网首页
js 保留位数

js 保留位数

作者: 李大嘴JimmyLee | 来源:发表于2020-04-02 11:50 被阅读0次

一、四舍五入相关
1、toFixed()方法
需注意,保留两位小数,将数值类型的数据改变成了字符串类型

 // 1.四舍五入
         var num =2.446242342;  
         num = num.toFixed(2); 
        console.log(num); //2.45
         console.log(typeof num); // string
2、Math.floor(),不四舍五入 ,向下取整
注意,不改变数据类型
 // 2.不四舍五入 向下取整
        num = Math.floor(num * 100) / 100;
        console.log(num); //2.44
         console.log(typeof num); // number
、字符串匹配
注意,先将数据转换为字符串,最后再转为数值类型
1 // 3.不四舍五入 字符串匹配再转换
2         num = Number(num.toString().match(/^\d+(?:\.\d{0,2})?/));
3         console.log(num); //2.44
4         console.log(typeof num); // number
4、四舍五入保留2位小数(若第二位小数为0,则保留一位小数)
注意,数据类型不变
 1 //4.四舍五入保留2位小数(若第二位小数为0,则保留一位小数)  
 2         function keepTwoDecimal(num) {  
 3              var result = parseFloat(num);  
 4              if (isNaN(result)) {  
 5                  alert('传递参数错误,请检查!');  
 6                  return false;  
 7              }  
 8              result = Math.round(num * 100) / 100;  
 9              return result;  
10         };
11          keepTwoDecimal(num);
12          console.log(num); //2.44
13          console.log(typeof num); //number
5、四舍五入保留2位小数(不够位数,则用0替补)
注意,数据类型变为字符串类型
 1 //5.四舍五入保留2位小数(不够位数,则用0替补)  
 2         function keepTwoDecimalFull(num) {  
 3              var result = parseFloat(num);  
 4              if (isNaN(result)) {  
 5                  alert('传递参数错误,请检查!');  
 6                  return false;  
 7              }  
 8              result = Math.round(num * 100) / 100;  
 9              var s_x = result.toString(); //将数字转换为字符串
10              
11              var pos_decimal = s_x.indexOf('.'); //小数点的索引值
12              
13 
14              // 当整数时,pos_decimal=-1 自动补0  
15              if (pos_decimal < 0) {  
16                  pos_decimal = s_x.length;  
17                  s_x += '.';  
18              }
19 
20              // 当数字的长度< 小数点索引+2时,补0  
21              while (s_x.length <= pos_decimal + 2) {  
22                  s_x += '0';  
23              }  
24              return s_x;  
25         }  
26 
27          console.log(keepTwoDecimalFull(120.5)); //120.50
28          console.log(typeof keepTwoDecimalFull(120.5)); //string
29          console.log(keepTwoDecimalFull(2.446242342)); //2.45
30          console.log(typeof keepTwoDecimalFull(2.446242342)); //string
二、浮点数保留两位小数
1、将浮点数四舍五入,取小数点后2位 
注意,数据类型不变
 1 //浮点数保留两位小数   
 2           //1.功能:将浮点数四舍五入,取小数点后2位   
 3           function toDecimal(x) {   
 4            var f = parseFloat(x);   
 5            if (isNaN(f)) {   
 6             return;   
 7            }   
 8            f = Math.round(x*100)/100;   
 9            return f;   
10           }   
11           console.log(toDecimal(3.1465926)); // 3.15
12           console.log(typeof toDecimal(3.1415926)); //number
强制保留2位小数,如:2,会在2后面补上00.即2.00  
注意,数据类型变为字符串类型
 //强制保留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;   
}   
          console.log(toDecimal2(3.1)); // 3.10
           console.log(typeof toDecimal2(3.1415926)); //string

3、保留两位小数 浮点数四舍五入 位数不够 不补0
注意,数据类型不变

 //保留两位小数 浮点数四舍五入 位数不够 不补0
           function fomatFloat(src,pos){    
             return Math.round(src*Math.pow(10, pos))/Math.pow(10, pos);    
           } 
            console.log(fomatFloat(3.12645,2)); // 3.13
           console.log(typeof fomatFloat(3.1415926)); //number

相关文章

网友评论

      本文标题:js 保留位数

      本文链接:https://www.haomeiwen.com/subject/dstxphtx.html