html浮点计算器,javascript公式计算引擎-解决浮点数计算误差-网页计算器

我们大家都知道,javascript在计算公式的时候,会出现误差,导致我们本来就应该正确的代码,出现了我们意想不到的结果。

例如:45.6*13=592.8000000000001(结果应该是592.8);

0.7+0.1=0.7999999999999999(应该是0.8);

//还有N多,在此不一一列举。

网上有一个比较认可的解决方法,就是自己去写加法,减法,乘法,除法。

例如:// 两个浮点数求和

function accAdd(num1,num2){

var r1,r2,m;

try{

r1 = num1.toString().split('.')[1].length;

}catch(e){

r1 = 0;

}

try{

r2=num2.toString().split(".")[1].length;

}catch(e){

r2=0;

}

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

// return (num1*m+num2*m)/m;

return Math.round(num1*m+num2*m)/m;

}

// 两个浮点数相减

function accSub(num1,num2){

var r1,r2,m;

try{

r1 = num1.toString().split('.')[1].length;

}catch(e){

r1 = 0;

}

try{

r2=num2.toString().split(".")[1].length;

}catch(e){

r2=0;

}

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

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

return (Math.round(num1*m-num2*m)/m).toFixed(n);

}

// 两数相除

function accDiv(num1,num2){

var t1,t2,r1,r2;

try{

t1 = num1.toString().split('.')[1].length;

}catch(e){

t1 = 0;

}

try{

t2=num2.toString().split(".")[1].length;

}catch(e){

t2=0;

}

r1=Number(num1.toString().replace(".",""));

r2=Number(num2.toString().replace(".",""));

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

}

function accMul(num1,num2){

var m=0,s1=num1.toString(),s2=num2.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);

}

但是有的时候,我们需要计算一连串的公式,并且里面包含了括号等等的复杂的符合运算,这个时候咱们应该怎么办呢?

例如:计算(0.7+0.1)÷(45.6*13)

这样的公式,我们是无法通过上面的自定义函数来解决的。因此今天给大家介绍一个比较好的计算引擎。

CalcEval.js

CalcEval引擎是一个专门解决javascript浮点数误差的的引擎,能够完美的解决各种复合的运算,最终输出正确的结果。

使用方法:

第一步:引入CalcEval.js

第二部:在页面上调用CalcEval的解析引擎入口var ce = new CalcEval();//创建引擎对象

var result = ce.eval("(0.7+0.1)/(45.6*13)");//调用引擎接口来解析公式的字符串,这个地方,必须要将公式以字符串的形式传入。

alert(result);//查看返回结果。

就这么简单的过程,就可以解决了每个浏览器中的浮点数计算bug。同时也可以制作自己的网页计算器了。

CalcEval.js下载地址:

-----------------------------------------------------

转载请注明来源此处

原地址:#

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值