原生js解决数字计算丢失精度问题

这个函数接收两个参数,用于对这两个数进行加法运算,返回结果。这个函数会将浮点数转换为字符串,并提取小数点后的位数,然后计算出两个数的位数差值,将差值转换为10的幂,再通过乘法将两个数转换为整数,最后再将结果除以10的幂,得到最终结果。这样可以避免浮点数计算时出现的精度损失问题。
/**
 * 加法函数,解决浮点数计算精度问题
 * @param {Number} arg1
 * @param {Number} arg2
 */
function add(arg1, arg2) {
    var r1, r2, m, c;
    try {
        r1 = arg1.toString().split('.')[1].length;
    } catch (e) {
        r1 = 0;
    }
    try {
        r2 = arg2.toString().split('.')[1].length;
    } catch (e) {
        r2 = 0;
    }
    c = Math.abs(r1 - r2);
    m = Math.pow(10, Math.max(r1, r2));
    if (c > 0) {
        var cm = Math.pow(10, c);
        if (r1 > r2) {
            arg1 = Number(arg1.toString().replace('.', ''));
            arg2 = Number(arg2.toString().replace('.', '')) * cm;
        } else {
            arg1 = Number(arg1.toString().replace('.', '')) * cm;
            arg2 = Number(arg2.toString().replace('.', ''));
        }
    } else {
        arg1 = Number(arg1.toString().replace('.', ''));
        arg2 = Number(arg2.toString().replace('.', ''));
    }
    return (arg1 + arg2) / m;
}
`
这里推荐一些第三方插件 BigNumber.js   decimal.js(推荐)  math.js(推荐)   bignumber.js
posted @ 2023-03-17 10:13  jialiangzai  阅读(17)  评论(0)    收藏  举报