简介
本文介绍3个JavaScript的数字处理第三方库的区别,它们是:big.js、bignumber.js 和 decimal.js。
这三个库都是同一个作者写的。
大致对比
- 包的大小
- big.js < bignumber.js < decimal.js
- big.js 是最小的任意精度的计算库。big.js 是三者中最小也最简单的,它只有 bignumber.js 一半的方法,不到 bignumber.js 的一半大。
功能
1、big.js
精度采用小数位;精度仅适用除法;4种舍入模式。
2、bignumber.js
配置选项;NaN;Infinity;精度采用小数位;精度仅适用于除法;随机数字;进制转换;9种舍入模式;模模式;模幂运算。
3、decimal.js
配置选项;NaN;Infinity;非整数次幂,exp,ln,log;三角函数;精度采用有效数字;所有操作均采取精度;随机数字;9种舍入模式;模模式;二进制,八进制,十六进制;二进制指数符号。
big.js、bignumber.js 和 decimal.js,这三个库都包含了 JavaScript 中 Number 类型的 toExponential、toFixed 和 toPrecision 方法。
性能
bignumber.js 和 decimal.js 存储值的进制比 big.js 更高,因此当操作大量数字时,前两者的速度会更快。
使用场景
1、bignumber.js
适合金融类应用,因为用户不用担心丢失精度,除非使用了涉及除法的操作。
2、decimal.js
适合科学类应用,因为它可以更有效的处理非常小或者非常大的数值。
例如,它没有 bignumber.js 的限制,即当将一个小指数值和一个大指数值相加时,bignumber.js 将使用完全精度来操作,这可能使得消耗很多时间。
- 进制
bignumber.js 和 decimal.js 也支持其它进制的计算,并支持前缀,比如十六进制的 0x。decimal.js 还可以使用二进制指数表示法处理二进制、八进制和十六进制,C 语言中就是如此。
bignumber.js处理十六进制:
var x = new BigNumber('ff.8', 16); x.toString(); // '255.5' x.toString(16); // 'ff.8'
decimal处理八进制、十六进制:
var x = new Decimal('0xff.8'); x.toString(); // '255.5' x.toHexadecimal(); // '0xff.8' x.toHex(3); // '0x1.ffp+7'
3、big.js
big.js 中,NAN 或者 Infinity 是不合法值,它不能处理除了十进制以外的其它进制。
big.js运行时的配置项仅限于设置小数位数、包含除法在内的四舍五入的运算模式,以及 toString 生成的科学计数法的指数值。
Big.DP = 7; // 最大小数位数 Big.RM = 4; // round half-up var x = new Big(5); x.div(3).toString(); // '1.6666667'
bignumber.js与decimal.js
decimal.js 最初是通过向 bignumber.js 添加对非整数次幂的支持来开发的,但后续作者决定将它作为一个单独的库来发布。
decimal.js和bignumber.js的最主要的区别在于:decimal.js 的精度是以有效数字而不是小数位数来指定的,并且所有的计算都舍入到该精度(类似于 Python 的小数模块),而不是只有涉及到除法的运算。
bignumber.js的精度配置
Bignumber.config({ DECIMAL_PLACES: 3, ROUNDING_MODE; 1 }); var x = new BigNumber('123.456789'); x.plus(1).toString(); // '124.456789'
decimal.js的精度配置
Decimal.set({ precision: 7, rounding: 4 }); var y = new Decimal('123.456789'); y.plus(1).toString(); // '124.4568'
decimal.js 还支持非整数次幂、三角函数、exp、ln、log 方法。这些额外的方法使得 decimal.js 比 bignumber.js 大得多。
官方地址