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

结尾

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

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

html5

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

以上就是常用的js保留两位小数的方法,希望对大家有帮助!

四、拓展阅读

最后

除了简历做到位,面试题也必不可少,整理了些题目,前面有117道汇总的面试到的题目,后面包括了HTML、CSS、JS、ES6、vue、微信小程序、项目类问题、笔试编程类题等专题。

img-blog.csdnimg.cn/img_convert/64ce8432d0f753e43f93972ad19fcd72.png)

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值