目录 前言 1. toFixed() 方法 2. Math.floor() 方法 3. 字符串+正则匹配 4. 强制保留2位小数(例如3.00) 5. 四舍五入保留2位小数(若第二位小数为0,则保留一位小数) 6. substring()方法 + indexOf(
          目录
- 前言
 - 1. toFixed() 方法
 - 2. Math.floor() 方法
 - 3. 字符串+正则匹配
 - 4. 强制保留2位小数(例如3.00)
 - 5. 四舍五入保留2位小数(若第二位小数为0,则保留一位小数)
 - 6. substring()方法 + indexOf()方法
 - 拓展
 - 总结
 
前言
日常开发中,后台会返给我们各式各样的数据,如果后台给你返回如下数据时,是不是就已经压制不住心中的怒火了,别急,其实前端处理这些数据还是非常简单的,下面用最简单的方法教你如何1分钟处理好这些数据。
返回数据示例:
3.1415926535897
85.452655625313
99.128532659596
话不多说,下面直接进入实战
1. toFixed() 方法
toFixed() 方法用于把数字转换为字符串,结果的小数点后有指定位数的数字。
实例
let numBer = 3.1415926; numBer = numBer.toFixed(2); console.log(numBer); // 3.14
注意:
该方法会将数值四舍五入,例如 3.148 经过 toFixed(2) 方法得到的结果将是 3.15 且 toFixed() 方法会改变数据类型为字符串。
2. Math.floor() 方法
Math.floor() 方法返回小于或等于一个给定数字的最大整数,可以理解 Math.floor() 为向下取整;其相对的是 Math.ceil(),此方法是向上取整。
实例
let numBer = 3.1415926; numBer = Math.floor(numBer * 100) / 100; console.log(numBer); // 3.14
注意:
该方法不会修改原有数据类型。
3. 字符串+正则匹配
实例
let numBer = 3.1415926;
numBer = Number(numBer.toString().match(/^\d+(?:\.\d{0,2})?/));
console.log(numBer);// 3.14
4. 强制保留2位小数(例如3.00)
实例
let numBer = 3; numBer = this.numWay(numBer);// 调用numWay方法 console.log(numBer); // 3.00
methods 方法代码
methods: {
  numWay(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;
  },
},
5. 四舍五入保留2位小数(若第二位小数为0,则保留一位小数)
实例
let numBer = 3.1001; numBer = this.numDelivery(numBer);// 调用numDelivery方法 console.log(numBer); // 3.1
methods 方法代码
methods: {
  numDelivery(num) {
    var result = parseFloat(num);
    if (isNaN(result)) {
      alert("传递参数错误,请检查!");
      return false;
    }
    result = Math.round(num * 100) / 100;
    return result;
  },
},
6. substring()方法 + indexOf()方法
substring() 方法用于提取字符串中介于两个指定下标之间的字符。返回的子串包括 开始 处的字符,但不包括 结束 处的字符
indexOf() 方法可返回某个指定的字符串值在字符串中首次出现的位置,如果没有找到匹配的字符串则返回 -1。
实例
let numBer = 3.1415926 + "";
var str = numBer.substring(0, numBer.indexOf(".") + 3);
console.log(str);// 3.14
拓展
为了方便,我们可以写一个专门的方法,需要的时候调用即可。如下代码:
<template>
  <div>
    {{this.getValue(719.0721)}}
  </div>
</template>
<script>
export default {
  methods: {
    getValue(val) {
      return val.toFixed(2);
    },
  },
};
</script>
页面展示

总结
到此这篇关于js保留两位小数最简单的实现方法的文章就介绍到这了,更多相关js保留两位小数内容请搜索自由互联以前的文章或继续浏览下面的相关文章希望大家以后多多支持自由互联!
