js decimal point high-precision calculation function finishing

js calculation of decimal high-precision calculation functions finishing

Specific code

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>只允许输入两位小数\高精度计算</title>
</head>
<body>


<input type="text" name="jiage" id="jiage" onblur="clearNoNum(this)"/><input type="text" name="geshu" id="geshu"/><button type="button" onclick="jia()">计算</button>


<script type="text/javascript">

    function clearNoNum(obj) {
     
     
        obj.value = obj.value.replace(/[^\d.]/g, ""); //清除“数字”和“.”以外的字符
        obj.value = obj.value.replace(/\.{2,}/g, "."); //只保留第一个. 清除多余的
        obj.value = obj.value.replace(".", "$#$").replace(/\./g, "").replace("$#$", ".");
        obj.value = obj.value.replace(/^(\-)*(\d+)\.(\d\d).*$/, '$1$2.$3');//只能输入两个小数
        if (obj.value.indexOf(".") < 0 && obj.value != "") {
     
     //以上已经过滤,此处控制的是如果没有小数点,首位不能为类似于 01、02的金额
            obj.value = parseFloat(obj.value);
        }
        if (!obj.value || obj.value == '0' || obj.value == '0.0' || obj.value == '0.00') {
     
     
            alert('退款金额不能为空');
            return;
        }
        //  正常得话继续调后端接口
    }

    function jia() {
     
     
        var jiage = document.getElementById('jiage').value;
        alert('jiage' + jiage);
        var geshu = document.getElementById('geshu').value;
        alert('geshu' + geshu);

        var zongshu = 0;
      zongshu = accAdd(jiage, geshu);
      alert('相加=' + zongshu);

      zongshu = Subtr(jiage, geshu);
      alert('相减=' + zongshu);

      zongshu = accMul(jiage, geshu);
      alert('相乘=' + zongshu);

      zongshu = accDiv(jiage, geshu);
      alert('相除=' + zongshu);

    }


    //加法函数,用来得到精确的加法结果
    //说明:javascript的加法结果会有误差,在两个浮点数相加的时候会比较明显。这个函数返回较为精确的加法结果。
    //调用:accAdd(arg1,arg2)
    //返回值:arg1加上arg2的精确结果
    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 (arg1 * m + arg2 * m) / m
    }

    //用法:
    //给Number类型增加一个add方法,调用起来更加方便。
    Number.prototype.add = function (arg) {
     
     
        return accAdd(arg, this);
    }
    //如:
    var t1 = 6.60;
    var t2 = 1.32;
    var t3 = 1.2;
    var t4 = 1.2;
    var t5 = 1.2;
    // alert(Number(t1).add(Number(t2)).add(Number(t3)).add(Number(t4)).add(Number(t5)));

    //减法函数,用来得到精确的减法结果
    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 ((arg1 * m - arg2 * m) / m).toFixed(n);
    }

    //乘法函数,用来得到精确的乘法结果
    //说明:javascript的乘法结果会有误差,在两个浮点数相乘的时候会比较明显。这个函数返回较为精确的乘法结果。
    //调用:accMul(arg1,arg2)
    //返回值:arg1乘以arg2的精确结果
    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方法,调用起来更加方便。
    Number.prototype.mul = function (arg) {
     
     
        return accMul(arg, this);
    }

    //除法函数,用来得到精确的除法结果
    //说明:javascript的除法结果会有误差,在两个浮点数相除的时候会比较明显。这个函数返回较为精确的除法结果。
    //调用:accDiv(arg1,arg2)
    //返回值:arg1除以arg2的精确结果
    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);
        }
    }


</script>
</body>
</html>

Guess you like

Origin blog.csdn.net/guo_qiangqiang/article/details/112347028