JS加减乘除(加校验,可做公共方法)

本文介绍了JavaScript中由于浮点数运算精度问题导致的不准确结果,并提供了解决方案。通过将浮点数转换为整数进行运算,然后再还原的方式,可以避免精度损失。文中给出了加、减、乘、除四个高精度运算的函数实现,适用于需要精确计算的场景。
摘要由CSDN通过智能技术生成

原生的js运算结果不一定准确,会丢失精度
解决方案的原理是,将浮点数乘以(扩大)10的n次方倍,把浮点数变为整数后再进行相应的运算,最后将得到的结果除以(缩小)10的n次方倍 
原理示例:将 console.log(1-0.8); 变为 console.log((1 * 10 - 0.8 * 10) / 10); 即可得到正确的值
根据上述原理,可以封装一些方法出来解决此类问题。如下所示(Math.pow(x, y);表示求x的y次方)

//加法运算    

function floatAdd(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;    

}    
       

//减法运算    

function floatSub(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}  

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值