js保留两位小数方法总结

举报
SHQ5785 发表于 2024/03/16 14:47:03 2024/03/16
【摘要】 一、前言此博文把相关保留两位小数的方法总结了一下,不同的场景用不同的方法,即用即取。 二、四舍五入相关 2.1 toFixed() 方法注意⚠️,保留两位小数,将数值类型的数据改变成了字符串类型。 var num =2.446242342; num = num.toFixed(2); console.log(num); //2.45 console.log(typeof num); ...

一、前言

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

二、四舍五入相关

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) {
 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保留两位小数的方法,希望对大家有帮助!

四、拓展阅读

【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。