我的问题是我必须在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
。
答案 0 :(得分:1)
正如@Felix Kling在评论中说的那样,如果您想使用本机js数字,那么也会受到限制。
但是,您可以像yy.toString()
一样打印bignumbers as strings。
是否要忽略字符串的缺点,将它们从字符串转换为本地js数字?使用parseFloat()
:parseFloat(ee.toString())