JS保留两位小数方法总结
序:
最近在做报表系统,经常需要用到金额保留两位小数,刚开始我一直用的是Angular中的过滤器number |2,但是,这无法满足我的需求。问题是,当用户离开文本框时,我需要将用户输入的内容转换成保留两位小数的格式,我想了好久,没有想出来,然后我试了toFixed()方法,这个方法也不可行,因为它将数据转换成了字符串,传给后台是错的。然后,我就找了其他方法。现在刚好有空,所以就把相关保留两位小数的方法总结了一下,不同的场景用不同的方法,即用即取
一、四舍五入相关
1、toFixed()方法
注意:保留两位小数,将数值类型的数据改变成了字符串类型
1 // 1.四舍五入
2 var num =2.446242342;
3 num = num.toFixed(2);
4 console.log(num); //2.45
5 console.log(typeof num); // string
2、Math.floor(),不四舍五入 ,向下取整
注意:不改变数据类型
1 // 2.不四舍五入 向下取整
2 num = Math.floor(num * 100) / 100;
3 console.log(num); //2.44
4 console.log(typeof num); // number
3、字符串匹配
注意:先将数据转换为字符串,最后再转为数值类型
1 // 3.不四舍五入 字符串匹配再转换
2 num = Number(num.toString().match(/^\d+(?:\.\d{0,2})?/));
3 console.log(num); //2.44
4 console.log(typeof num); // number
4、四舍五入保留2位小数(若第二位小数为0,则保留一位小数)
注意:数据类型不变
1 //4.四舍五入保留2位小数(若第二位小数为0,则保留一位小数)
2 function keepTwoDecimal(num) {
3 var result = parseFloat(num);
4 if (isNaN(result)) {
5 alert('传递参数错误,请检查!');
6 return false;
7 }
8 result = Math.round(num * 100) / 100;
9 return result;
10 };
11 keepTwoDecimal(num);
12 console.log(num); //2.44
13 console.log(typeof num); //number
5、四舍五入保留2位小数(不够位数,则用0替补)
注意:数据类型变为字符串类型
1 //5.四舍五入保留2位小数(不够位数,则用0替补)
2 function keepTwoDecimalFull(num) {
3 var result = parseFloat(num);
4 if (isNaN(result)) {
5 alert('传递参数错误,请检查!');
6 return false;
7 }
8 result = Math.round(num * 100) / 100;
9 var s_x = result.toString(); //将数字转换为字符串
10
11 var pos_decimal = s_x.indexOf('.'); //小数点的索引值
12
13
14 // 当整数时,pos_decimal=-1 自动补0
15 if (pos_decimal < 0) {
16 pos_decimal = s_x.length;
17 s_x += '.';
18 }
19
20 // 当数字的长度< 小数点索引+2时,补0
21 while (s_x.length <= pos_decimal + 2) {
22 s_x += '0';
23 }
24 return s_x;
25 }
26
27 console.log(keepTwoDecimalFull(120.5)); //120.50
28 console.log(typeof keepTwoDecimalFull(120.5)); //string
29 console.log(keepTwoDecimalFull(2.446242342)); //2.45
30 console.log(typeof keepTwoDecimalFull(2.446242342)); //string
二、浮点数保留两位小数
1、将浮点数四舍五入,取小数点后2位
注意:数据类型不变
1 //浮点数保留两位小数
2 //1.功能:将浮点数四舍五入,取小数点后2位
3 function toDecimal(x) {
4 var f = parseFloat(x);
5 if (isNaN(f)) {
6 return;
7 }
8 f = Math.round(x*100)/100;
9 return f;
10 }
11 console.log(toDecimal(3.1465926)); // 3.15
12 console.log(typeof toDecimal(3.1415926)); //number
2、强制保留2位小数,如:2,会在2后面补上00.即2.00
注意:数据类型变为字符串类型
1 //2.强制保留2位小数,如:2,会在2后面补上00.即2.00
2 function toDecimal2(x) {
3 var f = parseFloat(x);
4 if (isNaN(f)) {
5 return false;
6 }
7 var f = Math.round(x*100)/100;
8 var s = f.toString();
9 var rs = s.indexOf('.');
10 if (rs < 0) {
11 rs = s.length;
12 s += '.';
13 }
14 while (s.length <= rs + 2) {
15 s += '0';
16 }
17 return s;
18 }
19 console.log(toDecimal2(3.1)); // 3.10
20 console.log(typeof toDecimal2(3.1415926)); //string
3、保留两位小数 浮点数四舍五入 位数不够 不补0
注意:数据类型不变
1 // 3.保留两位小数 浮点数四舍五入 位数不够 不补0
2 function fomatFloat(src,pos){
3 return Math.round(src*Math.pow(10, pos))/Math.pow(10, pos);
4 }
5 console.log(fomatFloat(3.12645,2)); // 3.13
6 console.log(typeof fomatFloat(3.1415926)); //number