天天看點

javascript精确計算

一篇文章:

 4 個用于執行進階數學計算的 JavaScript 庫

numbers.js 

 Numeric Javascript 

accounting.js 

Tangle 

有時隻需要加減乘法能精确,沒必要用到庫。首先看下js浮點運算問題。

JS裡做小數的乘法運算時會出現浮點錯誤,具體可以測試一下:

<script>

alert(11*22.9)

</script>

結果是251.89999999999998 而不是251.9

這個問 題想必有很多人為之頭痛。那麼如何解決呢?在此給出解決辦法。

1、

alert(11*(22.9*10)/10);

解決問題的大概思路就是,先把 因數放大為整數,最後再除以相應的倍數,這樣就能得到正确的結果了。

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();

temp/=args[ i ].rate();

return temp

alert(tran(11,22.9));

該解決 辦法是比較麻煩的辦法,但是卻能讓你大概了解解決這個問題的實際過程。

//除法函數,用來得到精确的除法結果

//說明:javascript的除法結果會有誤差,在兩個浮點數相除的時候會比較明顯。這個函數傳回較為 精确的除法結果。

//調用:accDiv(arg1,arg2)

//傳回值:arg1除以arg2的精确結果

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類型增加一個div方法,調用起來更加 友善。

Number.prototype.div = function (arg){

return accDiv(this, arg);

//乘法函數,用來得到精确的乘法結果

//說明:javascript的乘法結果會有誤差,在兩個浮點數 相乘的時候會比較明顯。這個函數傳回較為精确的乘法結果。

//調用:accMul(arg1,arg2)

//傳回值:arg1乘以 arg2的精确結果

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類型增加一個mul方法,調用起來更加友善。

Number.prototype.mul = function (arg){

return accMul(arg, this);

//加法函數,用來得到精确的加法結果

//說明:javascript的加法 結果會有誤差,在兩個浮點數相加的時候會比較明顯。這個函數傳回較為精确的加法結果。

//調用:accAdd(arg1,arg2)

// 傳回值:arg1加上arg2的精确結果

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類型增加一個add方法,調用起來更加友善。

Number.prototype.add = function (arg){

return accAdd(arg,this);

說明:轉自百度空間潇潇雨部落格。

轉自:http://blog.sina.com.cn/s/blog_6fef4b860100p2n0.html

參考:javascript:void(0)

http://www.jb51.net/article/20267.htm

繼續閱讀