js小数计算丢失精度问题解决方法

                1 小数计算bug: 
			console.log( 1 - 0.8 );  //输出 0.19999999999999996 
			console.log( 6 * 0.7 );  //输出 4.199999999999999 
			console.log( 0.1 + 0.2 );  //输出 0.30000000000000004 
			console.log( 0.1 + 0.7 );  //输出 0.7999999999999999 
			console.log( 1.2 / 0.2 );  //输出 5.999999999999999 
			
			通过上面举出的例子可以看到,原生的js运算结果不一定准确,会丢失精度。 
		
		2 产生原因:
		
			计算机能读懂的是二进制,进行运算的时候,实际上是把数字转换为了二进制进行的 这个过程 丢失了精度
			
			
		3 通常的解决方法 计算之前*10的N次方 计算之后在除10的N次方 
		
			例如: console.log(1-0.8);  变为 console.log((1 * 10 - 0.8 * 10) / 10); 

			但是: 9033742.2*100 ----->903374219 (还是有一些特殊情况 不能直接*10的n次方)
		
		
		4 根据上述原理 做一下修改小数点截取转数字在计算,可以封装一些方法出来解决此类问题。如下所示(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}    
		    m=Math.pow(10,Math.max(r1,r2));    
		    //动态控制精度长度    
		    n=(r1>=r2)?r1:r2;    
		    return ((arg1*m-arg2*m)/m).toFixed(n);    
		}    
		       
		//乘    
		function floatMul(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);     
		}     
		      
		      
		//除   
		function floatDiv(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){}     
		        
		    r1=Number(arg1.toString().replace(".",""));  
		   
		    r2=Number(arg2.toString().replace(".",""));     
		    return (r1/r2)*Math.pow(10,t2-t1);     
		} 

 

  • 4
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值