背景:由于js在做浮点型数字的计算时,容易出现精度丢失的情况,为了处理这一问题,特编写四则运算的工具类。
原理:运用了我们小学所学的算术的小数相乘/相加/相减/相除后小数位的变化规律来进行精度的换算
首先,我们可以看一个例子,如下图:

四则运算工具类如下:
/**
* 解决两个数相加精度丢失问题
* @param a
* @param b
* @returns {Number}
*/
function floatAdd(a, b) {
var c, d, e;
if(undefined==a||null==a||""==a||isNaN(a)){a=0;}
if(undefined==b||null==b||""==b||isNaN(b)){b=0;}
try {
c = a.toString().split(".")[1].length;
} catch (f) {
c = 0;
}
try {
d = b.toString().split(".")[1].length;
} catch (f) {
d = 0;
}
e = Math.pow(10, Math.max(c, d));
return (floatMul(a, e) + floatMul(b, e)) / e;
}
/**
* 解决两个数相减精度丢失问题
* @param a
* @param b
* @returns {Number}
*/
function floatSub(a, b) {
var c, d, e;
if(undefined==a||null==a||""==a||isNaN(a)){a=0;}
if(undefined==b||null==b||""==b||isNaN(b)){b=0;}
try {
c = a.toString().split(".")[1].length;
} catch (f) {
c = 0;
}
try {
d = b.toString().split(".")[1].length;
} catch (f) {
d = 0;
}
e = Math.pow(10, Math.max(c, d));
return (floatMul(a, e) - floatMul(b, e)) / e;
}
/**
* 解决两个数相乘精度丢失问题
* @param a
* @param b
* @returns {Number}
*/
function floatMul(a, b) {
var c = 0,
d = a.toString(),
e = b.toString();
try {
c += d.split(".")[1].length;
} catch (f) {}
try {
c += e.split(".")[1].length;
} catch (f) {}
return Number(d.replace(".", "")) * Number(e.replace(".", "")) / Math.pow(10, c);
}
/**
* 解决两个数相除精度丢失问题
* @param a
* @param b
* @returns
*/
function floatDiv(a, b) {
var c, d, e = 0,
f = 0;
try {
e = a.toString().split(".")[1].length;
} catch (g) {}
try {
f = b.toString().split(".")[1].length;
} catch (g) {}
return c = Number(a.toString().replace(".", "")), d = Number(b.toString().replace(".", "")), floatMul(c / d, Math.pow(10, f - e));
}
本文介绍了一种JavaScript工具类,通过利用小数运算规则解决浮点数计算中的精度问题,提供floatAdd、floatSub、floatMul和floatDiv四个函数来确保四则运算的精确性。

643

被折叠的 条评论
为什么被折叠?



