首页 > 代码库 > javascript 精确加减乘除
javascript 精确加减乘除
最近一个项目中要使用 JS 实现自动计算的功能,本以为只是实现简单的加、减、乘、除就可以了,于是三下五除二做完了。
正当我窃喜的时候,发现问题了。。。
进行一些浮点数运算时,计算结果都是让我大跌眼镜啊,那个值让我哭笑不得,一长串的值,太牛了。。。
我那个纳闷啊!!不过还好牛人多,给了我一解决方案,嘿嘿。。。问题基本上解决了,为了表示感觉,我决定把代码贴出来,大家共享一下,希望能给部分人一些帮助。
Js代码
- //加法函数
- 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方法,,使用时直接用 .add 即可完成计算。
- Number.prototype.add = function (arg) {
- return accAdd(arg, this);
- };
- //减法函数
- function Subtr(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));
- //last modify by deeka
- //动态控制精度长度
- n = (r1 >= r2) ? r1 : r2;
- return ((arg1 * m - arg2 * m) / m).toFixed(n);
- }
- //给Number类型增加一个add方法,,使用时直接用 .sub 即可完成计算。
- Number.prototype.sub = function (arg) {
- return Subtr(this, arg);
- };
- //乘法函数
- 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方法,使用时直接用 .mul 即可完成计算。
- Number.prototype.mul = function (arg) {
- return accMul(arg, this);
- };
- //除法函数
- 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方法,,使用时直接用 .div 即可完成计算。
- Number.prototype.div = function (arg) {
- return accDiv(this, arg);
- };
//加法函数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方法,,使用时直接用 .add 即可完成计算。 Number.prototype.add = function (arg) { return accAdd(arg, this);};//减法函数function Subtr(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)); //last modify by deeka //动态控制精度长度 n = (r1 >= r2) ? r1 : r2; return ((arg1 * m - arg2 * m) / m).toFixed(n);}//给Number类型增加一个add方法,,使用时直接用 .sub 即可完成计算。 Number.prototype.sub = function (arg) { return Subtr(this, arg);};//乘法函数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方法,使用时直接用 .mul 即可完成计算。 Number.prototype.mul = function (arg) { return accMul(arg, this);}; //除法函数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方法,,使用时直接用 .div 即可完成计算。 Number.prototype.div = function (arg) { return accDiv(this, arg);};
使用方法:
Js代码
- //加法示例(其它的都类似)
- function calculate() {
- //数字1
- var num1 = 10;
- //数字2
- var num2 = 5;
- //计算 num1 + num2
- alert(num1.add(num2));
- }
//加法示例(其它的都类似)function calculate() { //数字1 var num1 = 10; //数字2 var num2 = 5; //计算 num1 + num2 alert(num1.add(num2));}
javascript 精确加减乘除
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。