前言
当你在开发网页或者移动应用时,你可能会遇到需要对数字进行精确处理的情况,比如需要将一个数字保留两位小数。而 JavaScript 作为一种广泛使用的编程语言,也提供了多种方法来实现这一功能。本文将向你介绍如何在 JavaScript 中保留两位小数。
返回数据示例:
3.1415926535897
85.452655625313
99.128532659596
话不多说,下面直接进入实战
1. toFixed() 方法
toFixed()
方法用于把数字转换为字符串,结果的小数点后有指定位数的数字。
参数 | 描述 |
---|---|
x | 必需的参数。规定小数的位数,可取 0 ~ 20 之间的值,包括 0 和 20,有些实现可以支持更大的数值范围。如果省略了该参数,将用 0 代替。 |
实例
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()
,此方法是向上取整。
参数 | 描述 |
---|---|
x | 必需的参数。任意数值或表达式。 |
实例
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()
方法用于提取字符串中介于两个指定下标之间的字符。返回的子串包括 开始 处的字符,但不包括 结束 处的字符
参数 | 描述 |
---|---|
from | 必需的参数。一个非负的整数,规定要提取的子串的第一个字符在 string Object 中的位置。 |
to | 非必需的参数。一个非负的整数,比要提取的子串的最后一个字符在 string Object 中的位置多 1。如果省略该参数,那么返回的子串会一直到字符串的结尾。 |
indexOf()
方法可返回某个指定的字符串值在字符串中首次出现的位置,如果没有找到匹配的字符串则返回 -1
。
参数 | 描述 |
---|---|
searchvalue | 必需的参数。规定需检索的字符串值。 |
start | 可选的整数参数。规定在字符串中开始检索的位置。它的合法取值是 0 到 string Object.length - 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>
页面展示