探究两种JS浮点溢出解决方案

开发 前端
你对JS浮点溢出的概念是否了解,这里通过实例向大家介绍一下JS浮点溢出的两种解决方案,希望对你的学习有所帮助。

本文和大家重点讨论一下JS浮点溢出的两种解决方案,一种就是是调用一个自定义的处理函数,两外一种方法就是使用toFixed方法返回一个以定点表示法表示的数字的字符串形式,请看下文详细介绍。

JS浮点溢出的两种解决方案

请运行以下代码,发现了什么。这就是JS浮点溢出。

  1. <scripttypescripttype="text/javascript"> 
  2. vara=38.8;  
  3. varb=6.8;  
  4. alert(a-b);  
  5. vara=134.22;  
  6. varb=6;  
  7. alert(a*b);  
  8. </script> 

JS浮点溢出有2中解决方案:

◆第一个调用一个处理函数

  1. functionoverflow(a,h,b)  
  2. {if(a.toString().indexOf(".")  
  3. <0&&b.toString().indexOf(".")<0){returneval(a+h+b);  
  4. }varalen=a.toString().split(".");if(alen.length==1){   
  5. alen=0;}else{alenalen=alen[1].length;  
  6. }varblen=b.toString().split(".");if(blen.length==1){   
  7. blen=0;}else{   
  8. blenblen=blen[1].length;}if(blen>alen)alen=blen;blen="1";  
  9. for(;alen>0;alen--){blenblen=blen+"0";  
  10. }switch(h){case"+":return(a*blen+b*blen)/blen;  
  11. break;case"-":return(a*blen-b*blen)/blen;  
  12. break;case"*":return((a*blen)*(b*blen))/(blen*blen);  
  13. break;default:return0;}} 

◆第二个使用toFixed方法返回一个以定点表示法表示的数字的字符串形式

再运行以下代码看看

  1. <scripttypescripttype="text/javascript"> 
  2. vara=38.8;  
  3. varb=6.8;  
  4. alert(overflow(a,"-",b));  
  5. vara=134.22;  
  6. varb=6;  
  7. alert((a*b).toFixed(2));  
  8. </script> 

【编辑推荐】

  1. IE6、IE7、IE8三大浏览器兼容性对比
  2. 兼容IE6,IE7,IE8,Firefox的CSS HACK写法
  3. IE6,IE7,火狐浏览器兼容性写法
  4. 完美实现IE6/IE7/FF浏览器兼容通用方法
  5. 解析Linux下如何用eclipse搭建J2ME开发环境

 

责任编辑:佚名 来源: robinhong.cn
相关推荐

2010-10-09 15:12:00

JavaScript溢出

2010-03-26 18:41:51

Nginx 502错误

2009-11-16 09:45:51

PHP上传文件大小

2009-11-16 13:46:28

PHP上传文件大小限制

2010-06-07 17:41:42

Sendmail 配置

2010-10-09 16:04:22

J2ME代码优化

2010-05-19 15:42:08

2021-01-11 10:10:23

开发文本溢出开发技术

2009-06-16 11:01:14

Java内存溢出

2010-09-26 16:04:48

JVM内存溢出

2019-05-15 10:59:50

开发者技能工具

2018-06-04 09:43:53

分层存储Linux

2010-09-17 16:18:43

Java内存溢出

2011-06-23 09:07:16

2010-09-07 09:18:16

DIV弹出窗口

2010-03-11 10:38:34

Python运算符

2010-01-06 16:53:57

JS两种语法

2010-05-28 09:49:48

MySQL远程连接

2010-09-15 08:41:25

IE6IE7Firefox兼容

2009-03-04 10:38:36

Troubleshoo桌面虚拟化Xendesktop
点赞
收藏

51CTO技术栈公众号