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

结尾

学习html5、css、javascript这些基础知识,学习的渠道很多,就不多说了,例如,一些其他的优秀博客。但是本人觉得看书也很必要,可以节省很多时间,常见的javascript的书,例如:javascript的高级程序设计,是每位前端工程师必不可少的一本书,边看边用,了解js的一些基本知识,基本上很全面了,如果有时间可以读一些,js性能相关的书籍,以及设计者模式,在实践中都会用的到。

开源分享:【大厂前端面试题解析+核心总结学习笔记+真实项目实战+最新讲解视频】

高级程序设计,是每位前端工程师必不可少的一本书,边看边用,了解js的一些基本知识,基本上很全面了,如果有时间可以读一些,js性能相关的书籍,以及设计者模式,在实践中都会用的到。

html5

 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) {
 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

3.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;
### 结尾

学习html5、css、javascript这些基础知识,学习的渠道很多,就不多说了,例如,一些其他的优秀博客。但是本人觉得看书也很必要,可以节省很多时间,常见的javascript的书,例如:javascript的高级程序设计,是每位前端工程师必不可少的一本书,边看边用,了解js的一些基本知识,基本上很全面了,如果有时间可以读一些,js性能相关的书籍,以及设计者模式,在实践中都会用的到。

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

高级程序设计,是每位前端工程师必不可少的一本书,边看边用,了解js的一些基本知识,基本上很全面了,如果有时间可以读一些,js性能相关的书籍,以及设计者模式,在实践中都会用的到。

![html5](https://i-blog.csdnimg.cn/blog_migrate/83aae72bc6397b00c241b41e7ae58e76.png)







评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值