js精確的加減乘除實例
更新時間:2017年11月14日 09:57:30 作者:zwpflc
下面小編就為大家?guī)硪黄猨s精確的加減乘除實例,具有非常好的參考價值。希望對大家有所幫助。一起跟隨小編過來看看吧
實例如下:
(function () {
var calc = {
/*
函數(shù),加法函數(shù),用來得到精確的加法結(jié)果
說明:javascript的加法結(jié)果會有誤差,在兩個浮點數(shù)相加的時候會比較明顯。這個函數(shù)返回較為精確的加法結(jié)果。
參數(shù):arg1:第一個加數(shù);arg2第二個加數(shù);d要保留的小數(shù)位數(shù)(可以不傳此參數(shù),如果不傳則不處理小數(shù)位數(shù))
調(diào)用:Calc.Add(arg1,arg2,d)
返回值:兩數(shù)相加的結(jié)果
*/
Add: function (arg1, arg2) {
arg1 = arg1.toString(), arg2 = arg2.toString();
var arg1Arr = arg1.split("."), arg2Arr = arg2.split("."), d1 = arg1Arr.length == 2 ? arg1Arr[1] : "", d2 = arg2Arr.length == 2 ? arg2Arr[1] : "";
var maxLen = Math.max(d1.length, d2.length);
var m = Math.pow(10, maxLen);
var result = Number(((arg1 * m + arg2 * m) / m).toFixed(maxLen));
var d = arguments[2];
return typeof d === "number" ? Number((result).toFixed(d)) : result;
},
/*
函數(shù):減法函數(shù),用來得到精確的減法結(jié)果
說明:函數(shù)返回較為精確的減法結(jié)果。
參數(shù):arg1:第一個加數(shù);arg2第二個加數(shù);d要保留的小數(shù)位數(shù)(可以不傳此參數(shù),如果不傳則不處理小數(shù)位數(shù)
調(diào)用:Calc.Sub(arg1,arg2)
返回值:兩數(shù)相減的結(jié)果
*/
Sub: function (arg1, arg2) {
return Calc.Add(arg1, -Number(arg2), arguments[2]);
},
/*
函數(shù):乘法函數(shù),用來得到精確的乘法結(jié)果
說明:函數(shù)返回較為精確的乘法結(jié)果。
參數(shù):arg1:第一個乘數(shù);arg2第二個乘數(shù);d要保留的小數(shù)位數(shù)(可以不傳此參數(shù),如果不傳則不處理小數(shù)位數(shù))
調(diào)用:Calc.Mul(arg1,arg2)
返回值:兩數(shù)相乘的結(jié)果
*/
Mul: function (arg1, arg2) {
var r1 = arg1.toString(), r2 = arg2.toString(), m, resultVal, d = arguments[2];
m = (r1.split(".")[1] ? r1.split(".")[1].length : 0) + (r2.split(".")[1] ? r2.split(".")[1].length : 0);
resultVal = Number(r1.replace(".", "")) * Number(r2.replace(".", "")) / Math.pow(10, m);
return typeof d !== "number" ? Number(resultVal) : Number(resultVal.toFixed(parseInt(d)));
},
/*
函數(shù):除法函數(shù),用來得到精確的除法結(jié)果
說明:函數(shù)返回較為精確的除法結(jié)果。
參數(shù):arg1:除數(shù);arg2被除數(shù);d要保留的小數(shù)位數(shù)(可以不傳此參數(shù),如果不傳則不處理小數(shù)位數(shù))
調(diào)用:Calc.Div(arg1,arg2)
返回值:arg1除于arg2的結(jié)果
*/
Div: function (arg1, arg2) {
var r1 = arg1.toString(), r2 = arg2.toString(), m, resultVal, d = arguments[2];
m = (r2.split(".")[1] ? r2.split(".")[1].length : 0) - (r1.split(".")[1] ? r1.split(".")[1].length : 0);
resultVal = Number(r1.replace(".", "")) / Number(r2.replace(".", "")) * Math.pow(10, m);
return typeof d !== "number" ? Number(resultVal) : Number(resultVal.toFixed(parseInt(d)));
}
};
window.Calc = calc;
}());
我已經(jīng)測試過了 可以直接使用!
以上這篇js精確的加減乘除實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript 文件加載與阻塞問題之性能優(yōu)化案例詳解
這篇文章主要介紹了JavaScript 文件加載與阻塞問題之性能優(yōu)化案例詳解,本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-09-09
JS常用正則表達(dá)式總結(jié)【經(jīng)典】
這篇文章主要介紹了JS常用正則表達(dá)式,總結(jié)分析了常見的數(shù)字、字符、郵箱、身份證、電話等的正則驗證技巧,需要的朋友可以參考下2017-05-05
js中的escape及unescape函數(shù)的php實現(xiàn)代碼
js中的escape及unescape函數(shù)的php實現(xiàn)代碼...2007-09-09
JavaScript動態(tài)創(chuàng)建二維數(shù)組的方法示例
這篇文章主要介紹了JavaScript動態(tài)創(chuàng)建二維數(shù)組的方法,結(jié)合實例形式分析了javascript動態(tài)創(chuàng)建二維數(shù)組的相關(guān)操作技巧與注意事項,需要的朋友可以參考下2019-02-02
js 轉(zhuǎn)json格式的字符串為對象或數(shù)組(前后臺)的方法
下面小編就為大家?guī)硪黄猨s 轉(zhuǎn)json格式的字符串為對象或數(shù)組(前后臺)的方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-11-11

