我有以下函数可以对jQuery中的某些业务逻辑进行乘法和除法
var rate = 39.5;
var IndiviualPercentageTaxes = 20;
var TotalPercentageTaxes = 20;
var r1 = rate* 100 / (100 + IndiviualPercentageTaxes);
var r2 = r1* (100 + TotalPercentageTaxes)/100;
var finalRate = Math.round(r2));
finalRate 39 ,但预期结果 40 .....
我可以轻松地重写程序,以避免在计算中丢失小数精度,如下所示:
var r2 = rate*(100 + TotalPercentageTaxes)/(100 +TotalPercentageTaxes)
然而,这将跳过r1,并且我需要r1用于整个程序中的其他目的。
这也引起了一种混乱,因为我把两个计算合二为一,没有人知道这个公式到底意味着什么。
有什么建议吗?
答案 0 :(得分:1)
你会做很多这类事吗?如果没有,那么只需使用正确的计算并给未来的读者留下评论,告诉他们为什么这样做。
但如果你做得很多,你需要真正的精确数字。那里有几个图书馆。这个:https://github.com/MikeMcl/bignumber.js /可能是最适合你的。
“Big Numbers”是来自Common Lisp和Java的术语,它捕获了非常大数字和非常长数字(用于精度)的想法,并且经常将数字保持在“大”中格式(即未解决的表达式),直到需要为止。