JavaScript进阶(十七):js保留两位小数方法总结_js除法保留两位小数

	- [3.3 保留两位小数 浮点数四舍五入 位数不够 不补0](#33____0_132)
+ [四、拓展阅读](#_145)

一、前言

此博文把相关保留两位小数的方法总结了一下,不同的场景用不同的方法,即用即取。

二、四舍五入相关

2.1 toFixed() 方法

注意⚠️,保留两位小数,将数值类型的数据改变成了字符串类型。

 var num =2.446242342;  
 num = num.toFixed(2); 
 console.log(num); //2.45
 console.log(typeof num); // string

2.2 Math.floor() 不四舍五入 ,向下取整

注意⚠️,不改变数据类型。

num = Math.floor(num \* 100) / 100;
console.log(num); //2.44
console.log(typeof num); // number

2.3 字符串匹配

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

num = Number(num.toString().match(/^\d+(?:\.\d{0,2})?/));
console.log(num); //2.44
console.log(typeof num); // number

2.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

2.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

三、浮点数保留两位小数

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

注⚠️,数据类型不变。

function toDecimal(x) {


### 最后

编程基础的初级开发者,计算机科学专业的学生,以及平时没怎么利用过数据结构与算法的开发人员希望复习这些概念为下次技术面试做准备。或者想学习一些计算机科学的基本概念,以优化代码,提高编程技能。这份笔记都是可以作为参考的。

**[开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】](https://bbs.csdn.net/topics/618166371)**

![名不虚传!字节技术官甩出的"保姆级"数据结构与算法笔记太香了](https://img-blog.csdnimg.cn/img_convert/a3e940acdcd55765852a8bfe54482664.png)



  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值