JavaScript保留两位小数方法示例

经常需要用到金额保留两位小数,刚开始用的是Angular中的过滤器number | 2,但是,这无法满足我的需求。问题是,当用户离开文本框时,我需要将用户输入的内容转换成保留两位小数的格式,然后我试了toFixed()方法,这个方法也不可行,因为它将数据转换成了字符串,传给后台是错的

JavaScript toFixed() 方法

把数字转换为字符串,结果的小数点后有指定位数的数字

var num = 5.56789;
var n=num.toFixed(2);//5.57

一、四舍五入相关

toFixed()方法

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

// 1.四舍五入
var num =2.446242342;  
num = num.toFixed(2); 
console.log(num); //2.45
console.log(typeof num); // string

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

注意,不改变数据类型

// 2.不四舍五入 向下取整
num = Math.floor(num * 100) / 100;
console.log(num); //2.44
console.log(typeof num); // number

字符串匹配

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

// 3.不四舍五入 字符串匹配再转换
num = Number(num.toString().match(/^\d+(?:\.\d{0,2})?/));
console.log(num); //2.44
console.log(typeof num); // number

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

注意,数据类型不变

//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位小数(不够位数,则用0替补)

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

//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

二、浮点数保留两位小数  Math.round

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

注意,数据类型不变

const ratePrefix = computed(() => (val) => {
  if (+val > 0) return `+${val.mul(100)}`;
  // if (+val > 0) return `+${Math.round(val * 10000) / 100}`;
  if (+val < 0) return `-${Math.round(val * 10000) / 100}`;
  return '';
});


Math.round(0.12344321 * 10000) / 100  //12.34

Math.round(0.12346321*10000) / 100    //12.35
//浮点数保留两位小数
//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

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

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

//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

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

注意,数据类型不变

// 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

posted @ 2020-08-13 22:47  JackieDYH  阅读(5)  评论(0编辑  收藏  举报  来源