一、前言
此博文把相关保留两位小数的方法总结了一下,不同的场景用不同的方法,即用即取。
二、四舍五入相关
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
保留两位小数的方法,希望对大家有帮助!
四、拓展阅读
评论