时间:2021-05-26
前言
因为计算机数字是浮点型,所以在计算过程中通常得到的并不是一个准确的数据,所以在做一些数组运算的时候比较头疼,我们这里就来写一下精确运算的方法
首先是加法 (这里以两个数据相加为例)
function add(arg1, arg2) { arg1 = arg1.toString(), arg2 = arg2.toString(); // 将传入的数据转化为字符串 var arg1Arr = arg1.split("."), // 将小数的数据从小数点的位置拆开 arg2Arr = arg2.split("."), d1 = arg1Arr.length == 2 ? arg1Arr[1] : "", // 获取第一个数的小数点的长度 d2 = arg2Arr.length == 2 ? arg2Arr[1] : ""; // 获取第二个数的小数点的长度 var maxLen = Math.max(d1.length, d2.length); // 获取小数点长度较大的值 var m = Math.pow(10, maxLen); // 这里表示10的小数点长度次方 也就是说如果小数点长度为2 m的值就是100 如果小数点长度是3 m的值就是1000如果不懂请自行查找api var result = Number(((arg1 * m + arg2 * m) / m).toFixed(maxLen)); // 将小数转化为整数后相加在除掉两个数乘过的倍数然后去小数点较长的长度的小数位数 var d = arguments[2]; // 第三个参数用户可以自行决定是否要传递 用来定义要保留的小数长度 return typeof d === "number" ? Number((result).toFixed(d)) : result;}add(12.123, 12)然后是减法(减法其实就是一个数组加上另一个数字的负数所以和加法逻辑相同)
function sun(arg1, arg2) {return add(arg1, -arg2)}其次是乘法
function mul(arg1, arg2) {var r1 = arg1.toString(), // 将传入的数据转化为字符串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); // 获取两个数字的小数位数的和// 乘积的算法就是去掉小数点做整数相乘然后除去10的所有小数位的次方resultVal = Number(r1.replace(".", "")) * Number(r2.replace(".", "")) / Math.pow(10, m);return typeof d !== "number" ? Number(resultVal) : Number(resultVal.toFixed(parseInt(d)));}最后是减法(除法和乘法就是一个相反的过程,不做过多解释)
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))); }总结
到此这篇关于js加减乘除精确运算方法的文章就介绍到这了,更多相关js加减乘除精确运算内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
html5外链式实现加减乘除,具体代码如下所示:加减乘除//引用jsa=3,b=2;js代码:functionsum(a,b){varc;c=a+b;retur
本文实例为大家分享了Vue.js制作立体计算器的具体方法,供大家参考,具体内容如下项目效果图这是一个简单的项目实现加减乘除运算项目结构代码展示计算器1.0.ht
html+js实现简单的计算器代码(加减乘除)functionsetOp(op,opTips){vartb=document.getElementById("t
本文实例为大家分享了Android实现简易计算器小程序的具体代码,供大家参考,具体内容如下目标效果:通过编写代码,可以实现整数和小数的加减乘除运算,以及删除和清
本篇博客学习一下Lua的运算符,比较简单,我将说明直接写到了代码中,代码如下。--算术运算符--二元运算符:+-*/^(加减乘除幂)--一元运算符:-(负值)-