js保留兩位小數(shù)最簡單的實現(xiàn)方法
目錄
- 前言
- 1. toFixed() 方法
- 2. Math.floor() 方法
- 3. 字符串+正則匹配
- 4. 強制保留2位小數(shù)(例如3.00)
- 5. 四舍五入保留2位小數(shù)(若第二位小數(shù)為0,則保留一位小數(shù))
- 6. substring()方法 + indexOf()方法
- 拓展
- 總結(jié)
前言
日常開發(fā)中,后臺會返給我們各式各樣的數(shù)據(jù),如果后臺給你返回如下數(shù)據(jù)時,是不是就已經(jīng)壓制不住心中的怒火了,別急,其實前端處理這些數(shù)據(jù)還是非常簡單的,下面用最簡單的方法教你如何1分鐘處理好這些數(shù)據(jù)。
返回數(shù)據(jù)示例:
3.1415926535897
85.452655625313
99.128532659596
話不多說,下面直接進入實戰(zhàn)
1. toFixed() 方法
toFixed()
方法用于把數(shù)字轉(zhuǎn)換為字符串,結(jié)果的小數(shù)點后有指定位數(shù)的數(shù)字。
實例
let numBer = 3.1415926;numBer = numBer.toFixed(2);console.log(numBer); // 3.14
注意:
該方法會將數(shù)值四舍五入,例如 3.148
經(jīng)過 toFixed(2)
方法得到的結(jié)果將是 3.15
且 toFixed()
方法會改變數(shù)據(jù)類型為字符串。
2. Math.floor() 方法
Math.floor()
方法返回小于或等于一個給定數(shù)字的最大整數(shù),可以理解 Math.floor()
為向下取整;其相對的是 Math.ceil()
,此方法是向上取整。
實例
let numBer = 3.1415926;numBer = Math.floor(numBer * 100) / 100;console.log(numBer); // 3.14
注意:
該方法不會修改原有數(shù)據(jù)類型。
3. 字符串+正則匹配
實例
let numBer = 3.1415926;numBer = Number(numBer.toString().match(/^\d+(?:\.\d{0,2})?/));console.log(numBer);// 3.14
4. 強制保留2位小數(shù)(例如3.00)
實例
let numBer = 3;numBer = this.numWay(numBer);// 調(diào)用numWay方法console.log(numBer); // 3.00
methods
方法代碼
methods: { numWay(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; },},
5. 四舍五入保留2位小數(shù)(若第二位小數(shù)為0,則保留一位小數(shù))
實例
let numBer = 3.1001;numBer = this.numDelivery(numBer);// 調(diào)用numDelivery方法console.log(numBer); // 3.1
methods
方法代碼
methods: { numDelivery(num) { var result = parseFloat(num); if (isNaN(result)) { alert("傳遞參數(shù)錯誤,請檢查!"); return false; } result = Math.round(num * 100) / 100; return result; },},
6. substring()方法 + indexOf()方法
substring()
方法用于提取字符串中介于兩個指定下標之間的字符。返回的子串包括 開始 處的字符,但不包括 結(jié)束 處的字符
indexOf()
方法可返回某個指定的字符串值在字符串中首次出現(xiàn)的位置,如果沒有找到匹配的字符串則返回 -1
。
實例
let numBer = 3.1415926 + "";var str = numBer.substring(0, numBer.indexOf(".") + 3);console.log(str);// 3.14
拓展
為了方便,我們可以寫一個專門的方法,需要的時候調(diào)用即可。如下代碼:
<template> <div> {{this.getValue(719.0721)}} </div></template><script>export default { methods: { getValue(val) { return val.toFixed(2); }, },};</script>
頁面展示
總結(jié)
到此這篇關(guān)于js保留兩位小數(shù)最簡單的實現(xiàn)方法的文章就介紹到這了,更多相關(guān)js保留兩位小數(shù)內(nèi)容請搜索以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持!
