js小数点高精度算法函数整理

本文档详细介绍了如何使用JavaScript编写精确的小数加减乘除函数,包括accAdd、Subtr、accMul和accDiv,确保在处理金钱计算时避免浮点误差。

js计算小数高精度计算函数整理

具体代码

<!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>
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值