JavaScript數(shù)字精度丟失問題的解決方案
JavaScript數(shù)字精度丟失問題
JavaScript使用64位浮點(diǎn)數(shù)表示數(shù)字(基于IEEE 754標(biāo)準(zhǔn)),這導(dǎo)致某些十進(jìn)制數(shù)字在計(jì)算過程中出現(xiàn)精度丟失。常見的場景包括小數(shù)運(yùn)算,如 0.1 + 0.2 的結(jié)果并非精確的 0.3,而是 0.30000000000000004。
解決方法
使用toFixed()
或toPrecision()
:對計(jì)算結(jié)果四舍五入,但這僅適用于顯示層面。
let result = (0.1 + 0.2).toFixed(2); // "0.30"
將數(shù)字轉(zhuǎn)換為整數(shù)再計(jì)算:將小數(shù)放大為整數(shù),運(yùn)算后再縮小。
let result = (0.1 * 10 + 0.2 * 10) / 10; // 0.3
使用Big.js、Decimal.js等庫:處理精度問題,專門解決浮點(diǎn)數(shù)運(yùn)算的庫。
const Decimal = require('decimal.js'); let result = new Decimal(0.1).plus(0.2).toNumber(); // 0.3
案例
console.log(0.1 + 0.2); // 輸出:0.30000000000000004 console.log((0.1 * 10 + 0.2 * 10) / 10); // 輸出:0.3
使用庫:
const Decimal = require('decimal.js'); let result = new Decimal(0.1).plus(0.2).toNumber(); // 輸出:0.3
到此這篇關(guān)于JavaScript數(shù)字精度丟失問題的解決方案的文章就介紹到這了,更多相關(guān)JavaScript數(shù)字精度丟失內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript 另類遍歷數(shù)組實(shí)現(xiàn)代碼
JavaScript 另類遍歷數(shù)組實(shí)現(xiàn)代碼,大家可以看下。2009-10-10javascript顯示動(dòng)態(tài)時(shí)間的方法匯總
本文給大家匯總介紹了3種javascript實(shí)現(xiàn)動(dòng)態(tài)顯示時(shí)間的方法及詳細(xì)示例,有需要的小伙伴可以參考下2018-07-07JavaScript中this函數(shù)使用實(shí)例解析
這篇文章主要介紹了JavaScript中this函數(shù)使用實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-02-02JavaScript?Canvas繪制六邊形網(wǎng)格
這篇文章主要為大家詳細(xì)介紹了JavaScript?Canvas繪制六邊形網(wǎng)格,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-01-01JavaScript位置參數(shù)實(shí)現(xiàn)原理及過程解析
這篇文章主要介紹了JavaScript位置參數(shù)實(shí)現(xiàn)原理及過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-09-09