標籤:次方 article 除法 底部 解決辦法 開始 ret .net try
在js浮點值的計算中,很多時候會出現不準確的情況,如下面的情況
console.log(2.2 + 2.1) // 4.300000000000001console.log(2.2 - 1.9) // 0.30000000000000027console.log(2.2 * 2.2)// 4.840000000000001console.log(2.1 / 0.3)// 7.000000000000001console.log(10 - 9.99)// 0.009999999999999787
然後上網找了一些解決辦法(參考博文底部連結),原理就是將浮點數從點號開始分開成兩個整數,然後進行計算。如下:
//加法
function add(a, b) {var c, d, e;try {c = a.toString().split(".")[1].length;} catch(f) {c = 0;}try {d = b.toString().split(".")[1].length;} catch(f) {d = 0;}return e = Math.pow(10, Math.max(c, d)), (mul(a, e) + mul(b, e)) / e;}//減法function sub(a, b) {var c, d, e;try {c = a.toString().split(".")[1].length;} catch(f) {c = 0;}try {d = b.toString().split(".")[1].length;} catch(f) {d = 0;}return e = Math.pow(10, Math.max(c, d)), (mul(a, e) - mul(b, e)) / e;}//除法function mul(a, b) {var c = 0,d = a.toString(),e = b.toString();try { c += d.split(".")[1].length;} catch(f) {}try {c += e.split(".")[1].length;} catch(f) {}return Number(d.replace(".", "")) * Number(e.replace(".", "")) / Math.pow(10, c);}//乘法function div(a, b) {var c, d, e = 0,f = 0;try {e = a.toString().split(".")[1].length;} catch(g) {}try {f = b.toString().split(".")[1].length;} catch(g) {}return c = Number(a.toString().replace(".", "")), d = Number(b.toString().replace(".", "")), mul(c / d, Math.pow(10, f - e));}
這個不失為一種很不錯的方法。但是當時做項目時好像只有一處地方用到,為了一處地方而粘貼這麼一段代碼,有點小題大作的感覺,後來我就臨時用了另一種方法,就先將浮點數乘以10的10次方變成整數,進行計算後將結果再除以10的10次方。結果如下。
可以看出,該方法還是有效,就是麻煩了點。值得注意的是,在除法那裡兩個值都乘以c之後,後面不需要再除以c,我犯了這個錯誤,所以我記下來了
好了,大概就這麼多了。
參考部落格連結:http://blog.csdn.net/qinshenxue/article/details/43671763
js浮點數的計算總結