我的问题是我必须使用javascript中的大数字(大十进制)进行计算,例如:
1.1e-40 + 1.1e-40
Javascript仅支持16位精度。所以我回到了MikeMcl bignumber.js的库
As explained in the API,要执行计算,请执行以下操作:
var y1 = new BigNumber(1.1e-40)
var y2 = new BigNumber(1.1e-40)
var yy = y1.plus(y2);
但是,yy返回一个带有
c: [220], e: -40 and s: 1
如何使用它找回原始号码?
例如,我尝试过:
yy.c * Math.pow(10, yy.e)
,但是这会产生舍入错误:2.1999999999999998e-38
。 最佳答案
就像@Felix Kling在评论中说的那样,如果您想使用本机js数字,那么您也会受到限制。
但是,您可以像yy.toString()
一样打印bignumbers as strings。
您是否想将它们从字符串转换为本地js数字,而忽略不利之处?使用parseFloat()
:parseFloat(ee.toString())