Vue进阶(幺玖陆):js保留两位小数方法总结

x33g5p2x  于2021-11-11 转载在 Vue.js  
字(2.2k)|赞(0)|评价(0)|浏览(463)

一、前言

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

二、四舍五入相关

2.1 toFixed() 方法

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

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

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

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

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

2.3 字符串匹配

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

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

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

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

  1. function keepTwoDecimal(num) {
  2. var result = parseFloat(num);
  3. if (isNaN(result)) {
  4. alert('传递参数错误,请检查!');
  5. return false;
  6. }
  7. result = Math.round(num * 100) / 100;
  8. return result;
  9. };
  10. keepTwoDecimal(num);
  11. console.log(num); //2.44
  12. console.log(typeof num); //number

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

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

  1. function keepTwoDecimalFull(num) {
  2. var result = parseFloat(num);
  3. if (isNaN(result)) {
  4. alert('传递参数错误,请检查!');
  5. return false;
  6. }
  7. result = Math.round(num * 100) / 100;
  8. var s_x = result.toString(); //将数字转换为字符串
  9. var pos_decimal = s_x.indexOf('.'); //小数点的索引值
  10. // 当整数时,pos_decimal=-1 自动补0
  11. if (pos_decimal < 0) {
  12. pos_decimal = s_x.length;
  13. s_x += '.';
  14. }
  15. // 当数字的长度< 小数点索引+2时,补0
  16. while (s_x.length <= pos_decimal + 2) {
  17. s_x += '0';
  18. }
  19. return s_x;
  20. }
  21. console.log(keepTwoDecimalFull(120.5)); //120.50
  22. console.log(typeof keepTwoDecimalFull(120.5)); //string
  23. console.log(keepTwoDecimalFull(2.446242342)); //2.45
  24. console.log(typeof keepTwoDecimalFull(2.446242342)); //string

三、浮点数保留两位小数

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

注⚠️,数据类型不变。

  1. function toDecimal(x) {
  2. var f = parseFloat(x);
  3. if (isNaN(f)) {
  4. return;
  5. }
  6. f = Math.round(x*100)/100;
  7. return f;
  8. }
  9. console.log(toDecimal(3.1465926)); // 3.15
  10. console.log(typeof toDecimal(3.1415926)); //number

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

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

  1. function toDecimal2(x) {
  2. var f = parseFloat(x);
  3. if (isNaN(f)) {
  4. return false;
  5. }
  6. var f = Math.round(x*100)/100;
  7. var s = f.toString();
  8. var rs = s.indexOf('.');
  9. if (rs < 0) {
  10. rs = s.length;
  11. s += '.';
  12. }
  13. while (s.length <= rs + 2) {
  14. s += '0';
  15. }
  16. return s;
  17. }
  18. console.log(toDecimal2(3.1)); // 3.10
  19. console.log(typeof toDecimal2(3.1415926)); //string

3.3 保留两位小数 浮点数四舍五入 位数不够 不补0

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

  1. function fomatFloat(src,pos){
  2. return Math.round(src*Math.pow(10, pos))/Math.pow(10, pos);
  3. }
  4. console.log(fomatFloat(3.12645,2)); // 3.13
  5. console.log(typeof fomatFloat(3.1415926)); //number

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

四、拓展阅读

  • 《Vue进阶(幺玖肆):JavaScript 浮点数精度计算》

相关文章