js保留兩位小數(shù)最簡單的實現(xiàn)方法
前言
日常開發(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)換為字符串,結果的小數(shù)點后有指定位數(shù)的數(shù)字。
| 參數(shù) | 描述 |
|---|---|
| x | 必需的參數(shù)。規(guī)定小數(shù)的位數(shù),可取 0 ~ 20 之間的值,包括 0 和 20,有些實現(xiàn)可以支持更大的數(shù)值范圍。如果省略了該參數(shù),將用 0 代替。 |
實例
let numBer = 3.1415926; numBer = numBer.toFixed(2); console.log(numBer); // 3.14
注意:
該方法會將數(shù)值四舍五入,例如 3.148 經(jīng)過 toFixed(2) 方法得到的結果將是 3.15 且 toFixed() 方法會改變數(shù)據(jù)類型為字符串。
2. Math.floor() 方法
Math.floor() 方法返回小于或等于一個給定數(shù)字的最大整數(shù),可以理解 Math.floor() 為向下取整;其相對的是 Math.ceil(),此方法是向上取整。
| 參數(shù) | 描述 |
|---|---|
| x | 必需的參數(shù)。任意數(shù)值或表達式。 |
實例
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.144. 強制保留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() 方法用于提取字符串中介于兩個指定下標之間的字符。返回的子串包括 開始 處的字符,但不包括 結束 處的字符
| 參數(shù) | 描述 |
|---|---|
| from | 必需的參數(shù)。一個非負的整數(shù),規(guī)定要提取的子串的第一個字符在 string Object 中的位置。 |
| to | 非必需的參數(shù)。一個非負的整數(shù),比要提取的子串的最后一個字符在 string Object 中的位置多 1。如果省略該參數(shù),那么返回的子串會一直到字符串的結尾。 |
indexOf() 方法可返回某個指定的字符串值在字符串中首次出現(xiàn)的位置,如果沒有找到匹配的字符串則返回 -1。
| 參數(shù) | 描述 |
|---|---|
| searchvalue | 必需的參數(shù)。規(guī)定需檢索的字符串值。 |
| start | 可選的整數(shù)參數(shù)。規(guī)定在字符串中開始檢索的位置。它的合法取值是 0 到 string Object.length - 1。如省略該參數(shù),則將從字符串的首字符開始檢索。 |
實例
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>頁面展示

總結
到此這篇關于js保留兩位小數(shù)最簡單的實現(xiàn)方法的文章就介紹到這了,更多相關js保留兩位小數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
JavaScript極簡入門教程(二):對象和函數(shù)
這篇文章主要介紹了JavaScript極簡入門教程(二):對象和函數(shù),本文講解了對象基礎知識、函數(shù)基礎知識、函數(shù)調(diào)用、異常、繼承等內(nèi)容,需要的朋友可以參考下2014-10-10
微信小程序?qū)崿F(xiàn)視頻播放器發(fā)送彈幕
這篇文章主要為大家詳細介紹了微信小程序?qū)崿F(xiàn)視頻播放器發(fā)送彈幕,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-04-04
js中異步函數(shù)async function變同步函數(shù)的簡單入門
這篇文章主要介紹了js中異步函數(shù)async function變同步函數(shù)的簡單入門,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04
基于HTML5上使用iScroll實現(xiàn)下拉刷新,上拉加載更多
本文主要介紹在HTML5中使用iScroll實現(xiàn)下拉刷新,上拉加載更多數(shù)據(jù)的方法,主要就是寫了兩個自定義函數(shù)pullDownAction和pullUpAction,分別在下拉和上拉的事件中調(diào)用他們。2016-05-05

