js加減乘除精確運(yùn)算方法實(shí)例代碼
前言
因?yàn)橛?jì)算機(jī)數(shù)字是浮點(diǎn)型,所以在計(jì)算過程中通常得到的并不是一個(gè)準(zhǔn)確的數(shù)據(jù),所以在做一些數(shù)組運(yùn)算的時(shí)候比較頭疼,我們這里就來寫一下精確運(yùn)算的方法
首先是加法 (這里以兩個(gè)數(shù)據(jù)相加為例)
function add(arg1, arg2) {
arg1 = arg1.toString(), arg2 = arg2.toString(); // 將傳入的數(shù)據(jù)轉(zhuǎn)化為字符串
var arg1Arr = arg1.split("."), // 將小數(shù)的數(shù)據(jù)從小數(shù)點(diǎn)的位置拆開
arg2Arr = arg2.split("."),
d1 = arg1Arr.length == 2 ? arg1Arr[1] : "", // 獲取第一個(gè)數(shù)的小數(shù)點(diǎn)的長度
d2 = arg2Arr.length == 2 ? arg2Arr[1] : ""; // 獲取第二個(gè)數(shù)的小數(shù)點(diǎn)的長度
var maxLen = Math.max(d1.length, d2.length); // 獲取小數(shù)點(diǎn)長度較大的值
var m = Math.pow(10, maxLen); // 這里表示10的小數(shù)點(diǎn)長度次方 也就是說如果小數(shù)點(diǎn)長度為2 m的值就是100 如果小數(shù)點(diǎn)長度是3 m的值就是1000如果不懂請自行查找api
var result = Number(((arg1 * m + arg2 * m) / m).toFixed(maxLen)); // 將小數(shù)轉(zhuǎn)化為整數(shù)后相加在除掉兩個(gè)數(shù)乘過的倍數(shù)然后去小數(shù)點(diǎn)較長的長度的小數(shù)位數(shù)
var d = arguments[2]; // 第三個(gè)參數(shù)用戶可以自行決定是否要傳遞 用來定義要保留的小數(shù)長度
return typeof d === "number" ? Number((result).toFixed(d)) : result;
}
add(12.123, 12)
然后是減法 (減法其實(shí)就是一個(gè)數(shù)組加上另一個(gè)數(shù)字的負(fù)數(shù)所以和加法邏輯相同)
function sun(arg1, arg2) {
return add(arg1, -arg2)
}
其次是乘法
function mul(arg1, arg2) {
var r1 = arg1.toString(), // 將傳入的數(shù)據(jù)轉(zhuǎn)化為字符串
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); // 獲取兩個(gè)數(shù)字的小數(shù)位數(shù)的和
// 乘積的算法就是去掉小數(shù)點(diǎn)做整數(shù)相乘然后除去10的所有小數(shù)位的次方
resultVal = Number(r1.replace(".", "")) * Number(r2.replace(".", "")) / Math.pow(10, m);
return typeof d !== "number" ? Number(resultVal) : Number(resultVal.toFixed(parseInt(d)));
}
最后是減法 (除法和乘法就是一個(gè)相反的過程,不做過多解釋)
function div(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)));
}
總結(jié)
到此這篇關(guān)于js加減乘除精確運(yùn)算方法的文章就介紹到這了,更多相關(guān)js加減乘除精確運(yùn)算內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
基于bootstrap插件實(shí)現(xiàn)autocomplete自動完成表單
這篇文章主要介紹了基于bootstrap插件實(shí)現(xiàn)autocomplete自動完成表單的相關(guān)資料,感興趣的朋友可以參考一下2016-05-05
JS數(shù)組方法concat()用法實(shí)例分析
這篇文章主要介紹了JS數(shù)組方法concat()用法,結(jié)合實(shí)例形式分析了JS數(shù)組concat()方法具體功能、用法及操作注意事項(xiàng),需要的朋友可以參考下2020-01-01
js 右側(cè)浮動層效果實(shí)現(xiàn)代碼(跟隨滾動)
因?yàn)轫?xiàng)目上有這樣的需求,在網(wǎng)上也查了些東西,之前是想找個(gè)差不多類似的套用一下。后來發(fā)覺沒有合適的,因時(shí)間緊迫就自己動手寫了一個(gè)簡單的 ,示例代碼如下 兼容火狐和IE7+2015-11-11
JavaScript實(shí)現(xiàn)網(wǎng)頁購物車
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)網(wǎng)頁購物車,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-06-06
JS插件clipboard.js實(shí)現(xiàn)一鍵復(fù)制粘貼功能
這篇文章主要介紹了JS插件clipboard.js實(shí)現(xiàn)一鍵復(fù)制粘貼功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-08-08
使用js判斷數(shù)組中是否包含某一元素(類似于php中的in_array())
這篇文章主要是對使用js判斷數(shù)組中是否包含某一元素(類似于php中的in_array())需要的朋友可以過來參考下,希望對大家有所幫助2013-12-12

