js保留两位小数方法总结

简介: js保留两位小数方法总结  最近在做结算系统,经常需要用到金额保留两位小数,刚开始我一直用的是Angular中的过滤器number |2,但是,这无法满足我的需求。问题是,当用户离开文本框时,我需要将用户输入的内容转换成保留两位小数的格式,我想了好久,没有想出来,然后我试了toFined()方法,这个方法也不可行,因为它将数据转换成了字符串,传给后台是错的。

js保留两位小数方法总结

  最近在做结算系统,经常需要用到金额保留两位小数,刚开始我一直用的是Angular中的过滤器number |2,但是,这无法满足我的需求。问题是,当用户离开文本框时,我需要将用户输入的内容转换成保留两位小数的格式,我想了好久,没有想出来,然后我试了toFined()方法,这个方法也不可行,因为它将数据转换成了字符串,传给后台是错的。然后,我就找了其他方法。现在刚好有空,所以就把相关保留两位小数的方法总结了一下,不同的场景用不同的方法,即用即取。

一、四舍五入相关

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

 

以上就是常用的js保留两位小数的方法,希望对大家有帮助!

不要让梦想变成空想,行动起来!

 

相关文章
|
8天前
|
JavaScript 前端开发 索引
JavaScript中的数组的内置方法全面讲解
JavaScript 数组提供了多种内置方法来高效操作数据。如 `push()` 和 `unshift()` 分别在数组尾部和头部添加元素;`pop()` 和 `shift()` 则移除尾部和头部的元素;`splice()` 可增删元素;`slice()` 创建子数组;`join()` 将数组转化为字符串;`indexOf()` 和 `includes()` 用于查找元素;`forEach()` 遍历数组。此外,`reverse()` 和 `sort()` 改变数组顺序;`fill()` 填充数组值;`slice()` 和 `concat()` 则分别用于创建子数组和合并数组。
17 2
|
7天前
|
前端开发 JavaScript
JavaScript——promise 是解决异步问题的方法嘛
JavaScript——promise 是解决异步问题的方法嘛
14 0
|
7天前
|
JavaScript 前端开发 索引
js遍历的方法与区别
js遍历的方法与区别
18 3
|
4天前
|
JSON JavaScript 前端开发
JavaScript实现字符串转json对象的方法
JavaScript实现字符串转json对象的方法
|
3天前
|
JavaScript 测试技术 索引
js数组方法汇总
js数组方法汇总
6 1
|
4天前
|
JavaScript 前端开发 索引
JS - includes 方法和 map 方法使用方式
这篇文章介绍了JavaScript中数组的`includes`方法和`map`方法的用法,包括它们的语法、参数说明和具体的示例代码。`includes`方法用于判断数组是否包含特定元素,而`map`方法用于对数组中的每个元素执行操作并返回新数组。
9 1
|
8天前
|
JavaScript API 索引
js中的reduce()方法 讲解 和实现
`reduce()` 方法对数组元素依次应用一个回调函数,将结果累计并最终返回单一值。语法为 `reduce(callback(accumulator, currentValue, currentIndex, array), initialValue)`。参数包括累计器(初次为初始值或首元素)、当前元素值、索引及数组自身。此方法需返回值供下一轮迭代使用。常见应用场景包括计算数组总和与平均值、统计元素频率、过滤与转换数组内容及去除重复项等。例如,可通过 `reduce()` 快速计算 `[1, 2, 3, 4, 5]` 的总和或对对象属性值求和。此外,还可自定义实现 `reduce()` 方法
26 1
|
8天前
|
存储 JavaScript
js数组的创建的方法讲解
数组是ECMAScript中最常用的类型之一,它是一组有序数据的集合,每个位置可存储任意类型的数据,并且大小动态变化。创建数组可通过`new Array()`或数组字面量如`[&#39;苹果&#39;, &#39;橘子&#39;]`。ES6引入了`Array.from()`和`Array.of()`:前者可将类数组或可迭代对象转为数组,后者则直接从参数创建数组。例如,`Array.from(&#39;hello&#39;)`将字符串转为字符数组,`Array.of(&#39;张三&#39;, &#39;李四&#39;)`直接创建包含名字的数组。这些方法增强了处理数组的能力。
8 1
|
4天前
|
JavaScript 前端开发
javascript中常见获取时间戳的方法
javascript中常见获取时间戳的方法
10 0
|
4天前
|
JavaScript 前端开发
js中this是指向的哪个全局变量,改变this指向的方法有什么?
js中this是指向的哪个全局变量,改变this指向的方法有什么?
6 0