翼度科技»论坛 编程开发 JavaScript 查看内容

JavaScript的数学计算库:decimal.js

2

主题

2

帖子

6

积分

新手上路

Rank: 1

积分
6
An arbitrary-precision Decimal type for JavaScript.
功能


  • 整数和浮点数
  • 简单但功能齐全的 API
  • 复制 JavaScript 和对象的许多方法Number.prototype Math
  • 还处理十六进制、二进制和八进制值
  • 比 Java 的 BigDecimal JavaScript 版本更快,更小,也许更容易使用
  • 无依赖关系
  • 广泛的平台兼容性:仅使用 JavaScript 1.5 (ECMAScript 3) 功能
  • 全面的文档和测试集
  • 在引擎盖下被数学使用.js
  • 包括一个 TypeScript 声明文件:decimal.d.ts

安装

该库是单个 JavaScript 文件 decimal.js 或 ES 模块 decimal.mjs
浏览器:
  1. [/code]Npm:
  2. [code]npm install decimal.js
复制代码
  1. const Decimal = require("decimal.js");
  2. import Decimal from "decimal.js";
  3. import { Decimal } from "decimal.js";
复制代码
使用

该库导出单个构造函数Decimal,该函数需要单个参数,即数字、字符串或十进制实例。
  1. x = new Decimal(123.4567);
  2. y = new Decimal("123456.7e-3");
  3. z = new Decimal(x);
  4. x.equals(y) && y.equals(z) && x.equals(z); // true
复制代码
加减乘除
  1. const a = new Decimal(4);
  2. const b = new Decimal(2);
  3. a.add(b); // 6
  4. a.sub(b); // 2
  5. a.mul(b); // 8
  6. a.div(b); // 2
复制代码
超过 javascript 允许的数字

如果使用超过 javascript 允许的数字的值,建议传递字符串而不是数字,以避免潜在的精度损失。
  1. new Decimal(1.0000000000000001); // '1'
  2. new Decimal(88259496234518.57); // '88259496234518.56'
  3. new Decimal(99999999999999999999); // '100000000000000000000'
  4. new Decimal(2e308); // 'Infinity'
  5. new Decimal(1e-324); // '0'
  6. new Decimal(0.7 + 0.1); // '0.7999999999999999'
复制代码
可读性

与 JavaScript 数字一样,字符串可以包含下划线作为分隔符以提高可读性。
  1. x = new Decimal("2_147_483_647");
复制代码
其它进制的数字

如果包含适当的前缀,则也接受二进制、十六进制或八进制表示法的字符串值。
  1. x = new Decimal("0xff.f"); // '255.9375'
  2. y = new Decimal("0b10101100"); // '172'
  3. z = x.plus(y); // '427.9375'
  4. z.toBinary(); // '0b110101011.1111'
  5. z.toBinary(13); // '0b1.101010111111p+8'
  6. x = new Decimal(
  7.     "0b1.1111111111111111111111111111111111111111111111111111p+1023"
  8. );
  9. // '1.7976931348623157081e+308'
复制代码
有关更多信息,请参阅  doc  目录中的  API  参考。

来源:https://www.cnblogs.com/guojikun/p/17491294.html
免责声明:由于采集信息均来自互联网,如果侵犯了您的权益,请联系我们【E-Mail:cb@itdo.tech】 我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x

举报 回复 使用道具