探究兩種JS浮點溢出解決方案
作者:admin
你對JS浮點溢出的概念是否了解,這里通過實例向大家介紹一下JS浮點溢出的兩種解決方案,希望對你的學(xué)習(xí)有所幫助。
本文和大家重點討論一下JS浮點溢出的兩種解決方案,一種就是是調(diào)用一個自定義的處理函數(shù),兩外一種方法就是使用toFixed方法返回一個以定點表示法表示的數(shù)字的字符串形式,請看下文詳細(xì)介紹。
JS浮點溢出的兩種解決方案
請運行以下代碼,發(fā)現(xiàn)了什么。這就是JS浮點溢出。
- <scripttypescripttype="text/javascript">
- vara=38.8;
- varb=6.8;
- alert(a-b);
- vara=134.22;
- varb=6;
- alert(a*b);
- </script>
JS浮點溢出有2中解決方案:
◆第一個調(diào)用一個處理函數(shù)
- functionoverflow(a,h,b)
- {if(a.toString().indexOf(".")
- <0&&b.toString().indexOf(".")<0){returneval(a+h+b);
- }varalen=a.toString().split(".");if(alen.length==1){
- alen=0;}else{alenalen=alen[1].length;
- }varblen=b.toString().split(".");if(blen.length==1){
- blen=0;}else{
- blenblen=blen[1].length;}if(blen>alen)alen=blen;blen="1";
- for(;alen>0;alen--){blenblen=blen+"0";
- }switch(h){case"+":return(a*blen+b*blen)/blen;
- break;case"-":return(a*blen-b*blen)/blen;
- break;case"*":return((a*blen)*(b*blen))/(blen*blen);
- break;default:return0;}}
◆第二個使用toFixed方法返回一個以定點表示法表示的數(shù)字的字符串形式
再運行以下代碼看看
- <scripttypescripttype="text/javascript">
- vara=38.8;
- varb=6.8;
- alert(overflow(a,"-",b));
- vara=134.22;
- varb=6;
- alert((a*b).toFixed(2));
- </script>
【編輯推薦】
- IE6、IE7、IE8三大瀏覽器兼容性對比
- 兼容IE6,IE7,IE8,Firefox的CSS HACK寫法
- IE6,IE7,火狐瀏覽器兼容性寫法
- 完美實現(xiàn)IE6/IE7/FF瀏覽器兼容通用方法
- 解析Linux下如何用eclipse搭建J2ME開發(fā)環(huán)境
責(zé)任編輯:佚名
來源:
robinhong.cn