javascript 小數(shù)乘法結(jié)果錯(cuò)誤的處理方法
一、用js計(jì)算
12.32 * 7 結(jié)果是多少?
答案:86.24000000000001
為什么會(huì)出現(xiàn)這種問(wèn)題?怎么解決?
js在處理小數(shù)的乘除法的時(shí)候有一個(gè)bug,解決的方法可以是:將小數(shù)變?yōu)檎麛?shù)來(lái)處理。
以上的計(jì)算可以改為:
12.32 * 100 * 7 /100
得出的結(jié)果是:86.24,正確。
另外再計(jì)算一下:
8.80 * 100 * 12 / 100
結(jié)果:105.60000000000002
38.80也會(huì)出現(xiàn)類似的問(wèn)題。
精確度增加10倍:
8.80 * 1000 * 12 / 1000
結(jié)果:105.6
正常了。
16.40 * 1000000 * 6 / 1000000
結(jié)果也有問(wèn)題
為了讓js執(zhí)行的更準(zhǔn)確,在以后的js小數(shù)計(jì)算中直接將值擴(kuò)大10000倍,再除以10000,就可以解決問(wèn)題。
var num = 38.80;
var num2 = 13;
alert(num * 10000 * 12 / 10000);
被乘和除的這個(gè)數(shù)經(jīng)過(guò)測(cè)試10000最合適,小了有些數(shù)字出問(wèn)題,大了(1000000)有些數(shù)字也出問(wèn)題。
二、
<script> Number.prototype.rate=function(){ varoStr=this.toString(); if(oStr.indexOf(".")==-1) return1; else returnMath.pow(10,parseInt(oStr.length-oStr.indexOf(".")-1)); } functiontran(){ args=tran.arguments; vartemp=1; for(i=0;i<args.length;i++) temp*=args[i]*args[i].rate(); for(i=0;i<args.length;i++) temp/=args[i].rate(); returntemp } alert(tran(11,22.9)); </script>
該解決 辦法是比較麻煩的辦法,但是卻能讓你大概了解解決這個(gè)問(wèn)題的實(shí)際過(guò)程。
//除法函數(shù),用來(lái)得到精確的除法結(jié)果 //說(shuō)明:javascript的除法結(jié)果會(huì)有誤差,在兩個(gè)浮點(diǎn)數(shù)相除的時(shí)候會(huì)比較明顯。這個(gè)函數(shù)返回較為精確的除法結(jié)果。 //調(diào)用:accDiv(arg1,arg2) //返回值:arg1除以arg2的精確結(jié)果 function accDiv(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){} with(Math){ r1=Number(arg1.toString().replace(".","")) r2=Number(arg2.toString().replace(".","")) return (r1/r2)*pow(10,t2-t1); } } //給Number類型增加一個(gè)div方法,調(diào)用起來(lái)更加 方便。 Number.prototype.div = function (arg){ return accDiv(this, arg); } //乘法函數(shù),用來(lái)得到精確的乘法結(jié)果 //說(shuō)明:javascript的乘法結(jié)果會(huì)有誤差,在兩個(gè)浮點(diǎn)數(shù)相乘的時(shí)候會(huì)比較明顯。這個(gè)函數(shù)返回較為精確的乘法結(jié)果。 //調(diào)用:accMul(arg1,arg2) //返回值:arg1乘以 arg2的精確結(jié)果 function accMul(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) } // 給Number類型增加一個(gè)mul方法,調(diào)用起來(lái)更加方便。 Number.prototype.mul = function (arg){ return accMul(arg, this); } //加法函數(shù),用來(lái)得到精確的加法結(jié)果 //說(shuō)明:javascript的加法結(jié)果會(huì)有誤差,在兩個(gè)浮點(diǎn)數(shù)相加的時(shí)候會(huì)比較明顯。這個(gè)函數(shù)返回較為精確的加法結(jié)果。 //調(diào)用:accAdd(arg1,arg2) // 返回值:arg1加上arg2的精確結(jié)果 function accAdd(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 } //給Number類型增加一個(gè)add方法,調(diào)用起來(lái)更加方便。 Number.prototype.add = function (arg){ return accAdd(arg,this); }
以上這篇javascript 小數(shù)乘法結(jié)果錯(cuò)誤的處理方法就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript實(shí)現(xiàn)九宮格點(diǎn)擊變色效果
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)九宮格點(diǎn)擊變色效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-08-08JavaScript簡(jiǎn)單判斷復(fù)選框是否選中及取出值的方法
這篇文章主要介紹了JavaScript簡(jiǎn)單判斷復(fù)選框是否選中及取出值的方法,涉及javascript遍歷復(fù)選框及元素取值的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08js省市區(qū)級(jí)聯(lián)查詢(插件版&無(wú)插件版)
這篇文章主要為大家詳細(xì)介紹了js省市區(qū)級(jí)聯(lián)查詢,包括插件版和無(wú)插件版,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03微信小程序?qū)崿F(xiàn)搜索功能并跳轉(zhuǎn)搜索結(jié)果頁(yè)面
這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)搜索功能并跳轉(zhuǎn)搜索結(jié)果頁(yè)面,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-05-05JavaScript實(shí)現(xiàn)鼠標(biāo)控制自由移動(dòng)的窗口
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)鼠標(biāo)控制自由移動(dòng)的窗口,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-06-06JS實(shí)現(xiàn)密碼框根據(jù)焦點(diǎn)的獲取與失去控制文字的消失與顯示效果
這篇文章主要介紹了JS實(shí)現(xiàn)密碼框根據(jù)焦點(diǎn)的獲取與失去控制文字的消失與顯示效果,可實(shí)現(xiàn)使用JavaScript判斷密碼框是否獲得焦點(diǎn)來(lái)隱藏與顯示提示文字,非常簡(jiǎn)單實(shí)用,需要的朋友可以參考下2015-11-11JS獲取表格內(nèi)指定單元格html內(nèi)容的方法
這篇文章主要介紹了JS獲取表格內(nèi)指定單元格html內(nèi)容的方法,涉及javascript中innerHTML屬性的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03Bootstrap導(dǎo)航條學(xué)習(xí)使用(一)
這篇文章主要為大家詳細(xì)介紹了Bootstrap導(dǎo)航條的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02