美文网首页
JS 加减乘除运算

JS 加减乘除运算

作者: 一沭丶 | 来源:发表于2018-08-09 14:20 被阅读37次

做的过程中发现加法还是不精确,
精确算法为啥不精确,因为里面的乘法不是精确乘法,所以修改了一下,加法没有问题了,其他的没有遇到问题所以没有重整。

var operationUtil = {
        accDiv: function (arg1, arg2) {
            //除法函数,用来得到精确的除法结果
            var t1 = 0,
                t2 = 0,
                r1,
                r2;
            try {
                t1 = arg1.toString().split(".")[1].length;
            } catch (e) { }
            try {
                t2 = arg2.toString().split(".")[1].length;
            } catch (e) { }
            with (Math) {
                r1 = Number(arg1.toString().replace(".", ""));
                r2 = Number(arg2.toString().replace(".", ""));
                return (r1 / r2) * pow(10, t2 - t1);
            }
        },
        accMul: function (arg1, arg2) {
            //乘法函数,用来得到精确的乘法结果
            var m = 0,
                s1 = arg1.toString(),
                s2 = arg2.toString();
            try {
                m += s1.split(".")[1].length;
            } catch (e) { }
            try {
                m += s2.split(".")[1].length;
            } catch (e) { }
            return (
                (Number(s1.replace(".", "")) * Number(s2.replace(".", ""))) /
                Math.pow(10, m)
            );
        },
        accAdd: function (arg1, arg2) {
            //加法函数,用来得到精确的加法结果
            var r1, r2, m;
            try {
                r1 = arg1.toString().split(".")[1].length;
            } catch (e) {
                r1 = 0;
            }
            try {
                r2 = arg2.toString().split(".")[1].length;
            } catch (e) {
                r2 = 0;
            }
            m = Math.pow(10, Math.max(r1, r2));
            return (this.accMul(arg1, m) + this.accMul(arg2, m)) / m;
        },
        accSub: function (arg1, arg2) {
            //减法函数
            var r1, r2, m, n;
            try {
                r1 = arg1.toString().split(".")[1].length;
            } catch (e) {
                r1 = 0;
            }
            try {
                r2 = arg2.toString().split(".")[1].length;
            } catch (e) {
                r2 = 0;
            }
            m = Math.pow(10, Math.max(r1, r2));
            //last modify by deeka
            //动态控制精度长度
            n = r1 >= r2 ? r1 : r2;
            return ((arg2 * m - arg1 * m) / m).toFixed(n);
        }
    };

相关文章

网友评论

      本文标题:JS 加减乘除运算

      本文链接:https://www.haomeiwen.com/subject/emoqbftx.html