function addFloatNumber() {
const args = arguments;
const len = args.length;
let initFloatLen = 0;
let sum = 0;
let strItem = '';
let tmpLen = 0;
for (key in args) {
strItem = args[key].toString();
if (strItem.indexOf('.') != -1) {
tmpLen = strItem.split('.')[1].length;
initFloatLen = initFloatLen < tmpLen ? tmpLen : initFloatLen;
}
} // for
const m = Math.pow(10, initFloatLen);
for (key in args) {
sum += args[key] * m;
}
return sum / m;
}
解决js中小数相加损失精度的问题
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
推荐阅读更多精彩内容
- 1.加法运算,避免数据相加小数点后产生多位数和计算精度损失。 num1 为 加数1 num2 为 加数2 2.减法...
- 利用Math.floor priceTotal = Math.floor(priceTotal * 100) / ...
- <!DOCTYPE html> //给Number类型增加 加法函数 Number.prototype.add =...
- float类型的数据相减,精度缺失问题 float类型的数据相加,精度缺失问题 float保留两位小数