1. 程式人生 > >js保留兩位小數方法總結

js保留兩位小數方法總結

var tostring angular float fixed pre 文本框 用戶輸入 希望

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保留兩位小數的方法,希望對大家有幫助!

不要讓夢想變成空想,行動起來!

js保留兩位小數方法總結