解決JS中乘法的浮點(diǎn)錯(cuò)誤的方法
JS里做小數(shù)的乘法運(yùn)算時(shí)會(huì)出現(xiàn)浮點(diǎn)錯(cuò)誤,具體可以測(cè)試一下:
<script>
alert(11*22.9)
</script>
結(jié)果是251.89999999999998 而不是251.9
這個(gè)問(wèn)題想必有很多人為之頭痛。那么如何解決呢?在此給出解決辦法。
1、
<script>
alert(11*(22.9*10)/10);
</script>
解決問(wèn)題的大概思路就是,先把因數(shù)放大為整數(shù),最后再除以相應(yīng)的倍數(shù),這樣就能得到正確的結(jié)果了。
2、
<script defer>
Number.prototype.rate=function(){
var oStr=this.toString();
if(oStr.indexOf(".")==-1)
return 1;
else
return Math.pow(10,parseInt(oStr.length-oStr.indexOf(".")-1));
}
function tran(){
args=tran.arguments;
var temp=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();
return temp
}
alert(tran(11,22.9));
</script>
該解決辦法是比較麻煩的辦法,但是卻能讓你大概了解解決這個(gè)問(wèn)題的實(shí)際過(guò)程。
也可以用四舍五入的方法, js中可以使用Math.round實(shí)現(xiàn)整數(shù)的四舍五入,如果需要實(shí)現(xiàn)精確到小數(shù)點(diǎn)多少位則需要編寫(xiě)函數(shù)了。
function ForDight(Dight,How) {
Dight = Math.round(Dight*Math.pow(10,How))/Math.pow(10,How);
return Dight;
}
//除法函數(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類(lèi)型增加一個(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類(lèi)型增加一個(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類(lèi)型增加一個(gè)add方法,調(diào)用起來(lái)更加方便。
Number.prototype.add = function (arg){
return accAdd(arg,this);
}
- javascript和jquery分別實(shí)現(xiàn)的九九乘法表代碼
- javascript(js)的小數(shù)點(diǎn)乘法除法問(wèn)題詳解
- jsp/javascript打印九九乘法表代碼
- JavaScript 字符串乘法
- JS實(shí)現(xiàn)上下左右對(duì)稱(chēng)的九九乘法表
- JavaScript實(shí)現(xiàn)99乘法表及隔行變色實(shí)例代碼
- JavaScript實(shí)現(xiàn)九九乘法表的簡(jiǎn)單實(shí)例
- 基于javascript實(shí)現(xiàn)九九乘法表
- jsp輸出九九乘法表的簡(jiǎn)單實(shí)例
- JavaScript九九乘法口訣表的簡(jiǎn)單實(shí)現(xiàn)
相關(guān)文章
深入理解javascript prototype的相關(guān)知識(shí)
這篇文章主要介紹了深入理解javascript prototype的相關(guān)知識(shí),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-09-09
IE Firefox 使用自定義標(biāo)簽的區(qū)別
IE Firefox 使用自定義標(biāo)簽的區(qū)別,需要的朋友可以參考下。2009-10-10
CSS(js)限制頁(yè)面顯示的文本字符長(zhǎng)度
限制頁(yè)面顯示的字符長(zhǎng)度,一直被眾多網(wǎng)友傾睬,本人也是一fans利用閑暇時(shí)間搜集整理了一些實(shí)用技巧,需要了解的朋友可以參考下2012-12-12
純CSS3代碼實(shí)現(xiàn)滑動(dòng)開(kāi)關(guān)效果
CSS33D炫酷左右滑動(dòng)開(kāi)關(guān)按鈕是一款非??岬腃SS3 3D開(kāi)關(guān)按鈕,點(diǎn)擊按鈕可以左右滑動(dòng),就像開(kāi)關(guān)打開(kāi)閉合一樣的效果,通過(guò)本篇文章給大家介紹純CSS3代碼實(shí)現(xiàn)滑動(dòng)開(kāi)關(guān)效果,需要的朋友可以參考下2015-08-08
Chart.js與ECharts.js圖表使用過(guò)程組件對(duì)比
chartjs只能基于canvas,雖然只有英文文檔,但定制化程度更高,社區(qū)成熟,功能就更加穩(wěn)定,ECharts.js可以基于svg或者canvas去渲染,有融合主流前端框架的社區(qū)庫(kù),另外ECharts.js還支持3d效果的圖表,相當(dāng)炫酷,國(guó)內(nèi)開(kāi)發(fā)者大多數(shù)使用這個(gè),有中文文檔2023-10-10

