最近在作結算系統,常常須要用到金額保留兩位小數,剛開始我一直用的是Angular中的過濾器number |2,可是,這沒法知足個人需求。問題是,當用戶離開文本框時,我須要將用戶輸入的內容轉換成保留兩位小數的格式,我想了很久,沒有想出來,而後我試了toFixed()方法,這個方法也不可行,由於它將數據轉換成了字符串,傳給後臺是錯的。而後,我就找了其餘方法。如今恰好有空,因此就把相關保留兩位小數的方法總結了一下,不一樣的場景用不一樣的方法,即用即取。spa
需注意,保留兩位小數,將數值類型的數據改變成了字符串類型code
1 // 1.四捨五入 2 var num =2.446242342; 3 num = num.toFixed(2); 4 console.log(num); //2.45 5 console.log(typeof num); // string
注意,不改變數據類型blog
1 // 2.不四捨五入 向下取整 2 num = Math.floor(num * 100) / 100; 3 console.log(num); //2.44 4 console.log(typeof num); // number
注意,先將數據轉換爲字符串,最後再轉爲數值類型索引
1 // 3.不四捨五入 字符串匹配再轉換 2 num = Number(num.toString().match(/^\d+(?:\.\d{0,2})?/)); 3 console.log(num); //2.44 4 console.log(typeof num); // number
注意,數據類型不變ci
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
注意,數據類型變爲字符串類型字符串
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
注意,數據類型不變string
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
注意,數據類型變爲字符串類型io
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
注意,數據類型不變console
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保留兩位小數的方法,但願對你們有幫助!function
不要讓夢想變成空想,行動起來!