js中精確計(jì)算加法和減法示例
更新時(shí)間:2014年03月28日 11:18:46 作者:
這篇文章主要介紹了js中如何精確計(jì)算加法和減法,需要的朋友可以參考下
/精確計(jì)算加法和減法。例如0.1+0.2=0.3或 0.1-0.2=-0.1
function addFn(dataOne,dataTwo){
var dataOneInt=dataOne.toString().split(".")[0];
var dataOneFloat="";
var dataTwoInt=dataTwo.toString().split(".")[0];
var dataTwoFloat="";
var lengthOne=0;
var lengthTwo=0;
var maxlength=0;
if(dataOne.toString().split(".").length==2){
dataOneFloat=dataOne.toString().split(".")[1];
lengthOne=dataOneFloat.toString().length;
}
if(dataTwo.toString().split(".").length==2){
dataTwoFloat=dataTwo.toString().split(".")[1];
lengthTwo=dataTwoFloat.toString().length;
}
maxLength=Math.max(lengthOne,lengthTwo);
for(var i=0;i<maxLength-lengthOne;i++){
dataOneFloat+="0";
}
for(var i=0;i<maxLength-lengthTwo;i++){
dataTwoFloat+="0";
}
/**
*對(duì)兩個(gè)數(shù)據(jù)進(jìn)行倍數(shù)放大
*使其都變?yōu)檎麛?shù)。因?yàn)檎麛?shù)計(jì)算
*比較精確。
*/
var one=dataOneInt+""+dataOneFloat;
var two=dataTwoInt+""+dataTwoFloat;
//alert("dataOne:"+dataOne+" dataTwo:"+dataTwo +" one:"+one+" two:"+two);
/**
*數(shù)據(jù)擴(kuò)大倍數(shù)后,經(jīng)計(jì)算的到結(jié)果,
*然后在縮小相同的倍數(shù)
*進(jìn)而得到正確的結(jié)果
*/
var result= (Number(one)+Number(two))/Math.pow(10,maxLength);
return result;
}
復(fù)制代碼 代碼如下:
function addFn(dataOne,dataTwo){
var dataOneInt=dataOne.toString().split(".")[0];
var dataOneFloat="";
var dataTwoInt=dataTwo.toString().split(".")[0];
var dataTwoFloat="";
var lengthOne=0;
var lengthTwo=0;
var maxlength=0;
if(dataOne.toString().split(".").length==2){
dataOneFloat=dataOne.toString().split(".")[1];
lengthOne=dataOneFloat.toString().length;
}
if(dataTwo.toString().split(".").length==2){
dataTwoFloat=dataTwo.toString().split(".")[1];
lengthTwo=dataTwoFloat.toString().length;
}
maxLength=Math.max(lengthOne,lengthTwo);
for(var i=0;i<maxLength-lengthOne;i++){
dataOneFloat+="0";
}
for(var i=0;i<maxLength-lengthTwo;i++){
dataTwoFloat+="0";
}
/**
*對(duì)兩個(gè)數(shù)據(jù)進(jìn)行倍數(shù)放大
*使其都變?yōu)檎麛?shù)。因?yàn)檎麛?shù)計(jì)算
*比較精確。
*/
var one=dataOneInt+""+dataOneFloat;
var two=dataTwoInt+""+dataTwoFloat;
//alert("dataOne:"+dataOne+" dataTwo:"+dataTwo +" one:"+one+" two:"+two);
/**
*數(shù)據(jù)擴(kuò)大倍數(shù)后,經(jīng)計(jì)算的到結(jié)果,
*然后在縮小相同的倍數(shù)
*進(jìn)而得到正確的結(jié)果
*/
var result= (Number(one)+Number(two))/Math.pow(10,maxLength);
return result;
}
您可能感興趣的文章:
- Javascript Math ceil()、floor()、round()三個(gè)函數(shù)的區(qū)別
- 使用js Math.random()函數(shù)生成n到m間的隨機(jī)數(shù)字
- JavaScript Math.floor方法(對(duì)數(shù)值向下取整)
- 介紹JavaScript中Math.abs()方法的使用
- Javascript四舍五入Math.round()與Math.pow()使用介紹
- js Math 對(duì)象的方法
- js關(guān)于精確計(jì)算和數(shù)值格式化以及直接引js文件
- js浮點(diǎn)數(shù)精確計(jì)算(加、減、乘、除)
- JavaScript使用math.js進(jìn)行精確計(jì)算操作示例
相關(guān)文章
微信小程序自定義tab實(shí)現(xiàn)多層tab嵌套
這篇文章主要為大家詳細(xì)介紹了微信小程序自定義tab實(shí)現(xiàn)多層tab嵌套,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07JS面向?qū)ο缶幊袒A(chǔ)篇(三) 繼承操作實(shí)例詳解
這篇文章主要介紹了JS面向?qū)ο缶幊汤^承操作,結(jié)合實(shí)例形式詳細(xì)分析了JS面向?qū)ο罄^承的具體概念、原理、實(shí)現(xiàn)方法及操作注意事項(xiàng),需要的朋友可以參考下2020-03-03向當(dāng)前style sheet中插入一個(gè)新的style實(shí)現(xiàn)方法
今天為了臨時(shí)解決頁(yè)面樣式問(wèn)題,為了方便,直接在這個(gè)公共的js里面向style sheet插入新的style rule,感興趣的朋友可以出納卡下哈2013-04-04JavaScript移除數(shù)組內(nèi)重復(fù)元素的方法
這篇文章主要介紹了JavaScript移除數(shù)組內(nèi)重復(fù)元素的方法,實(shí)例分析了javascript遍歷數(shù)組及刪除等操作的相關(guān)技巧,需要的朋友可以參考下2015-03-03iframe中子父類窗口調(diào)用JS的方法及注意事項(xiàng)
本文給大家介紹iframe中子父類窗口調(diào)用JS的方法及注意事項(xiàng),介紹的超詳細(xì),需要的朋友快來(lái)學(xué)習(xí)下2015-08-08手機(jī)端圖片縮放旋轉(zhuǎn)全屏查看PhotoSwipe.js插件實(shí)現(xiàn)
這篇文章主要介紹了手機(jī)端圖片縮放旋轉(zhuǎn)全屏查看PhotoSwipe.js插件實(shí)現(xiàn),感興趣的小伙伴們可以參考一下2016-08-08JavaScript調(diào)試之console.log調(diào)試的一個(gè)小技巧分享
日常開發(fā)中經(jīng)常會(huì)需要console來(lái)查看當(dāng)前對(duì)象的值。當(dāng)然用debugger會(huì)更全面的查看,但是總有只喜歡用console的,比如我。下面這篇文章主要給大家分享了關(guān)于JavaScript調(diào)試之console.log調(diào)試的一個(gè)小技巧,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-08-08