Js小数运算精度缺失的解决方法

项目场景:

提示:项目需求截图:


问题描述

众所周知Js做运算时0.1+0.2不等于0.3,目前项目需要计算关于金额的选项,涉及到金额保留后两位。保单欠款是根据用户输入的保单应收和保单欠款自动计算的。


原因分析:

产生浮点数计算精度不准确的原因:

在计算机角度,计算机算的是二进制,而不是十进制。二进制后变成了无线不循环的数,而计算机可支持浮点数的小数部分可支持到52位,所有两者相加,在转换成十进制,得到的数就不准确了,加减乘除运算原理一样。
提示:js小数计算精度缺失是历史遗留问题,被人诟病很多,不过也有办法解决,js小数计算会缺失精度,但正数不会有这个问题,所以计算时把小数扩大相应倍数,让它变成整数计算,最后结果再除以相应倍数,就得到了想要的结果。

不过我这边使用的是mathjs第三方库。下面是mathjs的解决办法


解决方案:

提示:mathjs解决方案:

官网:https://mathjs.org/index.html

安装

javascript 复制代码
npm install mathjs

引入

javascript 复制代码
import * as math from 'mathjs'

封装成方法

javascript 复制代码
import * as math from 'mathjs';
//例如:num1-num2,在需要的地方直接调用subtract 传二个参数(num1,num2)
    // 加
	add(num1,num2){
		return math.add(math.bignumber(num1),math.bignumber(num2));
	},
	// 减
	subtract(num1,num2){
		return math.subtract(math.bignumber(num1),math.bignumber(num2));
	},
	// 乘
	multiply(num1,num2){
		return math.multiply(math.bignumber(num1),math.bignumber(num2));
	},
	// 除
	divide(num1,num2){
		return math.divide(math.bignumber(num1),math.bignumber(num2));
}
相关推荐
We་ct10 分钟前
前端包管理工具与Monorepo全面解析
前端·javascript·npm·pnpm·yarn·monorepo·包管理
油丶酸萝卜别吃25 分钟前
高效处理数组差异:JS中新增、删除、交集的最优解(Set实现)
开发语言·前端·javascript
gskyi28 分钟前
时间格式化神器:智能显示相对时间
开发语言·javascript·ecmascript
挖稀泥的工人36 分钟前
AI 打字跟随优化
前端·javascript·vue.js
jiayong2337 分钟前
第 11 课:把筛选条件同步到 URL
开发语言·前端·javascript
Mintopia42 分钟前
一次讲清"慢"的本质:CPU、IO、网络到底谁在拖后腿
javascript
im_AMBER1 小时前
学习 Redux Toolkit :从 Context 误区到 createSlice 实践
前端·javascript·学习·react.js·前端框架
SuperEugene1 小时前
Vue3 配置驱动表格:列配置/操作配置/分页配置,统一表格渲染|配置驱动开发实战篇
前端·javascript·vue.js·驱动开发·架构
weixin_471383031 小时前
[特殊字符] React Flow 从入门到理解
开发语言·前端·javascript
五仁火烧1 小时前
前端不传文件,也能用 multipart/form-data
前端·javascript·vue.js·node.js