當(dāng)前位置:
首頁(yè) >
JS 四则运算精度丢失解决方案
發(fā)布時(shí)間:2025/3/18
28
豆豆
生活随笔
收集整理的這篇文章主要介紹了
JS 四则运算精度丢失解决方案
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
相信絕大部分js開(kāi)發(fā)者遇見(jiàn)過(guò)這個(gè)問(wèn)題,原理很多文章都有解釋,我這就不多說(shuō)了,直接上解決方案的代碼。
代碼:
//加法 Number.prototype.add = function(arg){ var r1,r2,m; try{r1=this.toString().split(".")[1].length}catch(e){r1=0} try{r2=arg.toString().split(".")[1].length}catch(e){r2=0} m=Math.pow(10,Math.max(r1,r2)) return (this.mul(m) + arg.mul(m)) / m; } //減法 Number.prototype.sub = function (arg){ return this.add(-arg); } //乘法 Number.prototype.mul = function (arg) { var m=0,s1=this.toString(),s2=arg.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.prototype.div = function (arg){ var t1=0,t2=0,r1,r2; try{t1=this.toString().split(".")[1].length}catch(e){} try{t2=arg.toString().split(".")[1].length}catch(e){} with(Math){ r1=Number(this.toString().replace(".","")) r2=Number(arg.toString().replace(".","")) return (r1/r2)*pow(10,t2-t1); } }這段代碼是參考自JS 精度問(wèn)題,然而這代碼還有點(diǎn)小瑕疵,經(jīng)過(guò)小修改后如上。
經(jīng)過(guò)親測(cè)是沒(méi)什么問(wèn)題的,大家可以自由測(cè)試下。
若該文章解決了你碰到的問(wèn)題,請(qǐng)點(diǎn)個(gè)贊~哈哈
調(diào)用方法如下:
如: 0.1+0.2,2.22+0.1,2480-2479.99
0.1.add(0.2); 2.22.add(0.1); 2480.sub(2479.99);總結(jié)
以上是生活随笔為你收集整理的JS 四则运算精度丢失解决方案的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 初衷
- 下一篇: Spring Ioc 源码分析(一)--