ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

js保留X位小数方法总结(以2位为例)

2021-07-27 11:29:52  阅读:152  来源: 互联网

标签:四舍五入 console log js num 100 位为例 小数


一、四舍五入相关

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

3、字符串匹配

注意,先将数据转换为字符串,最后再转为数值类型

 // 3.不四舍五入 字符串匹配再转换
         num = Number(num.toString().match(/^\d+(?:\.\d{0,2})?/));
         console.log(num); //2.44
         console.log(typeof num); // number

4、四舍五入保留2位小数(若第二位小数为0,则保留一位小数)

注意,数据类型不变

 //4.四舍五入保留2位小数(若第二位小数为0,则保留一位小数)  
         function keepTwoDecimal(num) {  
              var result = parseFloat(num);  
              if (isNaN(result)) {  
                  alert('传递参数错误,请检查!');  
                  return false;  
              }  
              result = Math.round(num * 100) / 100;  
              return result;  
        };
          keepTwoDecimal(num);
          console.log(num); //2.44
          console.log(typeof num); //number

5、四舍五入保留2位小数(不够位数,则用0替补)

注意,数据类型变为字符串类型

 //5.四舍五入保留2位小数(不够位数,则用0替补)  
         function keepTwoDecimalFull(num) {  
              var result = parseFloat(num);  
              if (isNaN(result)) {  
                  alert('传递参数错误,请检查!');  
                  return false;  
              }  
              result = Math.round(num * 100) / 100;  
              var s_x = result.toString(); //将数字转换为字符串
              
              var pos_decimal = s_x.indexOf('.'); //小数点的索引值
              
 
              // 当整数时,pos_decimal=-1 自动补0  
              if (pos_decimal < 0) {  
                  pos_decimal = s_x.length;  
                  s_x += '.';  
              }
 
              // 当数字的长度< 小数点索引+2时,补0  
              while (s_x.length <= pos_decimal + 2) {  
                  s_x += '0';  
              }  
              return s_x;  
         }  
 
          console.log(keepTwoDecimalFull(120.5)); //120.50
          console.log(typeof keepTwoDecimalFull(120.5)); //string
          console.log(keepTwoDecimalFull(2.446242342)); //2.45
          console.log(typeof keepTwoDecimalFull(2.446242342)); //string

二、浮点数保留两位小数

1、将浮点数四舍五入,取小数点后2位 

注意,数据类型不变

 //浮点数保留两位小数   
           //1.功能:将浮点数四舍五入,取小数点后2位   
           function toDecimal(x) {   
            var f = parseFloat(x);   
            if (isNaN(f)) {   
             return;   
            }   
            f = Math.round(x*100)/100;   
            return f;   
           }   
           console.log(toDecimal(3.1465926)); // 3.15
           console.log(typeof toDecimal(3.1415926)); //number

2、强制保留2位小数,如:2,会在2后面补上00.即2.00  

注意,数据类型变为字符串类型

 //2.强制保留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

注意,数据类型不变

 // 3.保留两位小数 浮点数四舍五入 位数不够 不补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

标签:四舍五入,console,log,js,num,100,位为例,小数
来源: https://blog.csdn.net/Healer_xiaozhen/article/details/119139175

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有