當(dāng)前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
JS 四则运算精度丢失解决方案
生活随笔
收集整理的這篇文章主要介紹了
JS 四则运算精度丢失解决方案
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
相信絕大部分js開發(fā)者遇見過這個(gè)問題,原理很多文章都有解釋,我這就不多說了,直接上解決方案的代碼。
代碼:
//加法 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 精度問題,然而這代碼還有點(diǎn)小瑕疵,經(jīng)過小修改后如上。
經(jīng)過親測(cè)是沒什么問題的,大家可以自由測(cè)試下。
若該文章解決了你碰到的問題,請(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)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 初衷
- 下一篇: voxel 与 pixel