javascript 涉及float的精确加减乘除取余运算

发布时间:2024年01月24日

js 中使用 decimal.js 进行不丢失精度的小数计算

npm install?decimal.js

Decimal.js 支持以下运算符的重载:

+:加法
-:减法
*:乘法
/:除法
%:取模运算
**:指数运算
++:自增运算
--:自减运算
这些运算符被重载后,可以直接用于 Decimal 对象之间的运算,例如:

const a = new Decimal('2.5');
const b = new Decimal('3');

const c = a + b; // 等同于 a.plus(b)
const d = b - a; // 等同于 b.minus(a)
const e = a * b; // 等同于 a.times(b)
const f = a / b; // 等同于 a.div(b)
const g = b % a; // 等同于 b.mod(a)
const h = a ** 2; // 等同于 a.toPower(2)

let i = new Decimal('0');
i++; // 等同于 i = i.plus(1);
i--; // 等同于 i = i.minus(1);

以下是它的通常用法:

import Decimal from "decimal.js"  // 具体文件中引入

//加
let a = 1
let b = 6 
// a 与 b 可以是 任何类型,Decimal 内部会自己处理兼容
// 下面两种都可以 可以带 new 也不可以不带 new
let res = new Decimal(a).add(new Decimal(b)) 
let res = Decimal(a).add(Decimal(b)) 

//减
let a = "4"
let b = "8"
// a 与 b 可以是 任何类型,Decimal 内部会自己处理兼容
// 下面两种都可以 可以带 new 也不可以不带 new
let res = new Decimal(a).sub(new Decimal(b)) 
let res = Decimal(a).sub(Decimal(b)) 

//乘
let a = 1
let b = 6 
// a 与 b 可以是 任何类型,Decimal 内部会自己处理兼容
// 下面两种都可以 可以带 new 也不可以不带 new
let res = new Decimal(a).mul(new Decimal(b)) 
let res = Decimal(a).mul(Decimal(b)) 

//除
let a = 1
let b = 6 
// a 与 b 可以是 任何类型,Decimal 内部会自己处理兼容
// 下面两种都可以 可以带 new 也不可以不带 new
let res = new Decimal(a).div(new Decimal(b)) 
let res = Decimal(a).div(Decimal(b)) 

//比较大小
const num1 = new Decimal('1.23');
const num2 = new Decimal('4.56');

// 比较 num1 和 num2 的大小
const result = num1.comparedTo(num2);

if (result === -1) {
  console.log('num1 小于 num2');
} else if (result === 0) {
  console.log('num1 等于 num2');
} else if (result === 1) {
  console.log('num1 大于 num2');
}

//转换
let res = Decimal(a).div(Decimal(b)).toNumber()  // 结果转换成 Number
let res = Decimal(a).div(Decimal(b)).toString()  // 结果转换成 String

//查看有几位小数 (注意不计算 小数点 最后 末尾 的 0)
y = new Decimal(987000.000)
y.sd()                                   // '3' 有效位数
y.sd(true)                               // '6' 总共位数

// 保留 多少个位数 (小数位 会补0)
x = 45.6
x.toPrecision(5)                         // '45.600'

// 保留 多少位有效位数(小数位 不会补0,是计算的有效位数)
x = new Decimal(9876.5)
x.toSignificantDigits(6)                 // '9876.5' 不会补0 只是针对有效位数

// 保留几位小数 , 跟 js 中的 number 一样
toFixed
x = 3.456
// 向下取整
x.toFixed(2, Decimal.ROUND_DOWN)  // '3.45' (舍入模式 向上0 向下1 四舍五入 4,7)
// 向上取整
Decimal.ROUND_UP 

//四舍五入
ROUND_HALF_UP

https://gitee.com/mirrors/decimal.js-light

文章来源:https://blog.csdn.net/s01896/article/details/135817227
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。