JS 四则运算精度丧失解决方案

置信绝大部分js开发者遇见过这个题目,道理许多文章都有诠释,我这就不多说了,直接上处理方案的代码。

代码:

    //加法   
    Number.prototype.add = function(arg){   
        var r1,r2,m;   
        try{r1=this.toString().split(".")[1].length}catch(e){r1=0}   
        try{r2=arg.toString().split(".")[1].length}catch(e){r2=0}   
        m=Math.pow(10,Math.max(r1,r2))   
        return (this.mul(m) + arg.mul(m)) / m;   
    }  
    
    //减法   
    Number.prototype.sub = function (arg){   
        return this.add(-arg);   
    }   

    //乘法   
    Number.prototype.mul = function (arg)   
    {   
        var m=0,s1=this.toString(),s2=arg.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.prototype.div = function (arg){   
        var t1=0,t2=0,r1,r2;   
        try{t1=this.toString().split(".")[1].length}catch(e){}   
        try{t2=arg.toString().split(".")[1].length}catch(e){}   
        with(Math){   
            r1=Number(this.toString().replace(".",""))   
            r2=Number(arg.toString().replace(".",""))   
            return (r1/r2)*pow(10,t2-t1);   
        }   
    }

这段代码是参考自JS 精度题目,然而这代码还有点小瑕疵,经由小修改后如上。
经由亲测是没什么题目的,人人能够自在测试下。
若该文章处理了你遇到的题目,请点个赞~哈哈

挪用要领以下:

如: 0.1+0.2,2.22+0.1,2480-2479.99

0.1.add(0.2);
2.22.add(0.1);
2480.sub(2479.99);
    原文作者:wuweisen
    原文地址: https://segmentfault.com/a/1190000007155192
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞