js保留两位小数方法总结

一、四舍五入相关

1、toFixed()方法

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

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

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

注意,不改变数据类型

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

3、字符串匹配

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

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

4、四舍五入保留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

5、四舍五入保留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

二、浮点数保留两位小数

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

注意,数据类型不变

				//浮点数保留两位小数   
				//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,会在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

3、保留两位小数 浮点数四舍五入 位数不够 不补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

  • 22
    点赞
  • 146
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端报刊

你的鼓励将是我创作的最大动力!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值