日期:2014-05-16  浏览次数:20364 次

js浮点数运算问题

运算不准的童鞋们:

?

// console.log(37.5*5.5)

//加法函数,用来得到精确的加法结果?

//说明:javascript的加法结果会有误差,在两个浮点数相加的时候会比较明显。这个函数返回较为精确的加法结果。?

//调用:accAdd(arg1,arg2)?

//返回值:arg1加上arg2的精确结果?

function accAdd(arg1, arg2) {

? ? var r1, r2, m;

? ? try { r1 = arg1.toString().split(".")[1].length } catch (e) { r1 = 0 }

? ? try { r2 = arg2.toString().split(".")[1].length } catch (e) { r2 = 0 }

? ? m = Math.pow(10, Math.max(r1, r2))

? ? return (arg1 * m + arg2 * m) / m

}

//给Number类型增加一个add方法,调用起来更加方便。?

Number.prototype.add = function(arg) {

? ? return accAdd(arg, this);

}

?

//减法函数,用来得到精确的减法结果

//说明:javascript的减法结果会有误差,在两个浮点数相减的时候会比较明显。这个函数返回较为精确的加法结果。

//调用:accSub(arg1,arg2)?

//返回值:arg1减去arg2的精确结果

?

function accSub(arg1, arg2) {

? ? var r1, r2, m, n;

? ? try { r1 = arg1.toString().split(".")[1].length } catch (e) { r1 = 0 }

? ? try { r2 = arg2.toString().split(".")[1].length } catch (e) { r2 = 0 }

? ? m = Math.pow(10, Math.max(r1, r2));

? ? n = (r1 >= r2) ? r1 : r2;

? ? return ((arg1 * m - arg2 * m) / m).toFixed(n);

}

//给Number类型增加一个add方法,调用起来更加方便。

Number.prototype.sub = function(arg) {

? ? return accSub(arg, this);

}

var num = 2355.47+4457.86+5599.22+3856.02+6672.88+3992.4+7213.7+5688.97;

console.log(num);

console.log(num.toFixed(2));

num = 2355.47.add(4457.86).add(5599.22).add(3856.02).add(6672.88).add(3992.4).add(7213.7).add(5688.97);

console.log(num);

console.log(num.toFixed(2));

?

?

+++++++++++++++++++++++++++++++ 补充其他两个函数:

//除法函数,用来得到精确的除法结果?

//说明:javascript的除法结果会有误差,在两个浮点数相除的时候会比较明显。这个函数返回较为精确的除法结果。?

//调用:accDiv(arg1,arg2)?

//返回值:arg1除以arg2的精确结果

?

function accDiv(arg1, arg2) {

? ? var t1 = 0, t2 = 0, r1, r2;

? ? try { t1 = arg1.toString().split(".")[1].length } catch (e) { }

? ? try { t2 = arg2.toString().split(".")[1].length } catch (e) { }

? ? with (Math) {

? ? ? ? r1 = Number(arg1.toString().replace(".", ""))

? ? ? ? r2 = Number(arg2.toString().replace(".", ""))

? ? ? ? return (r1 / r2) * pow(10, t2 - t1);

? ? }

}

//给Number类型增加一个div方法,调用起来更加方便。?

Number.prototype.div = function(arg) {

? ? return accDiv(this, arg);

}

//乘法函数,用来得到精确的乘法结果?

//说明:javascript的乘法结果会有误差,在两个浮点数相乘的时候会比较明显。这个函数返回较为精确的乘法结果。?

//调用:accMul(arg1,arg2)?

//返回值:arg1乘以arg2的精确结果?

function accMul(arg1, arg2) {

? ? var m = 0, s1 = arg1.toString(), s2 = arg2.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类型增加一个mul方法,调用起来更加方便。?

Number.prototype.mul = function(arg) {

? ? return accMul(arg, this);

}

//加法函数,用来得到精确的加法结果?

//说明:javascript的加法结果会有误差,在两个浮点数相加的时候会比较明显。这个函数返回较为精确的加法结果。?

//调用:accAdd(arg1,arg2)?

//返回值:arg1加上arg2的精确结果?

function accAdd(arg1, arg2) {

? ? var r1, r2, m;

? ? try { r1 = arg1.toString().split(".")[1].length } catch (e) { r1 = 0 }

? ? try { r2 = arg2.toString().split(".")[1].length } catch (e) { r2 = 0 }

? ? m = Math.pow(10, Math.max(r1, r2))

? ? return (arg1 * m + arg2 * m) / m

}