Aobodo.Com

July 15, 2008

JS jscript做小数乘法运算出现浮点错误的解决办法

Filed under: life's shadow — Tags: , , , — admin @ 12:51 pm
在Javascript里计算小数乘法,容易出现浮点错误,例如:
  1. <script>
  2. document.write (1.1*1.3);
  3. document.write ("<br>");
  4. document.write (1.2*1.1);
  5. </script>
输出结果:
  1. 1.4300000000000001
  2. 1.32
解决问题的思路就是,先把因数放大为整数,最后再除以相应的倍数,这样就能得到正确的结果了。解决办法如下:
1、 在算式中解决
  1. <script>
  2. alert(1.1*(1.3*10)/10);
  3. </script>
2、添加到Number的原型方法里
  1. <script>
  2. Number.prototype.rate=function(){
  3. var oStr=this.toString();
  4. if(oStr.indexOf(".")==-1)
  5. return 1;
  6. else
  7. return Math.pow(10,parseInt(oStr.length-oStr.indexOf(".")-1));
  8. }
  9. function tran(){
  10. args=tran.arguments;
  11. var temp=1;
  12. for(i=0;i < args.length;i++)
  13. temp*=args[ i ]*args[ i ].rate();
  14. for(i=0;i < args.length;i++)
  15. temp/=args[ i ].rate();
  16. return temp;
  17. }
  18. </script></script>
使用方法:假如11*22.9,可以这样写tran(11,22.9),这样,问题就解决了。

1 Comment »

  1. 奇思妙想解难题:

    还是这个问题,今天用JS计算两个小数,20*2.24,结果得到的答案是44.800000000000004,这是什么啊?于是我开始怀疑上面这个解决方案的可靠性,不可否认,大部分的小数计算确实是正确的,但是今天这两组数的乘积却是错误的。

    如何解决呢,用parseInt是不行的,结果直接成了40,如果分开计算呢,分成20*2+20*0.24,经过测试,结果是正确的,于是又测了多组小数相乘,哈哈,结果都是正确的!

    实然的一个想法,却解决了一大堆代码解决不了的难题,真是高兴死我了!!

    Comment by jena — October 30, 2008 @ 9:09 pm

RSS feed for comments on this post. TrackBack URL

Leave a comment

You must be logged in to post a comment.

Powered by WordPress, Design by Jena