1. 程式人生 > >js 加減乘除運算 進度問題 解決方案

js 加減乘除運算 進度問題 解決方案

//加法函式
function accAdd(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
(Number((arg1 * m).toFixed(0)) + Number((arg2 * m).toFixed(0))) / m; } //給Number型別增加一個add方法,,使用時直接用 .add 即可完成計算。 Number.prototype.add = function (arg) { return accAdd(arg, this); }; //減法函式 function Subtr(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 Number(((arg1 * m - arg2 * m) / m).toFixed(n)); } //給Number型別增加一個add方法,,使用時直接用 .sub 即可完成計算。
Number.prototype.sub = function (arg) { return Subtr(this, arg); }; //乘法函式 function accMul(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); } //給Number型別增加一個mul方法,使用時直接用 .mul 即可完成計算。 Number.prototype.mul = function (arg) { return accMul(arg, this); }; //除法函式 function accDiv(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); } } //給Number型別增加一個div方法,,使用時直接用 .div 即可完成計算。 Number.prototype.div = function (arg) { return accDiv(this, arg); };