zoukankan      html  css  js  c++  java
  • 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 (arg1 * m + arg2 * m) / 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 ((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);  
    };   
    //加法示例(其它的都类似)  
    //加法示例(其它的都类似)  
    function calculate() {  
        //数字1  
                    var num1 = 10;  
                    //数字2  
                    var num2 = 5;  
                    //计算 num1 + num2  
                    alert(num1.add(num2));  
    } 

    文章出处:http://tangshuang.iteye.com/blog/701710

  • 相关阅读:
    使用DBUtils获取Blob类型数据
    关于 JupyterLab 与 Pandas 资源整理
    关于 Conda 在 MacOS Catalina 环境变量问题
    推荐一个符合 OIDC 规范的 JAVA 客户端
    关于 Chrome 的 Kiosk 模式
    Kubernetes 中的服务发现与负载均衡
    Prometheus 监控领域最锋利的“瑞士军刀”
    CD 基金会、Jenkins、Jenkins X、Spinnaker 和 Tekton 的常问问题
    Installing on Kubernetes with NATS Operator
    升级 ASP.NET Core 3.0 设置 JSON 返回 PascalCase 格式与 SignalR 问题
  • 原文地址:https://www.cnblogs.com/foreverfendou/p/5109106.html
Copyright © 2011-2022 走看看