首页前端开发JavaScriptjs加减乘除精确运算方法实例代码

js加减乘除精确运算方法实例代码

时间2024-01-31 15:03:02发布访客分类JavaScript浏览123
导读:收集整理的这篇文章主要介绍了js加减乘除精确运算方法实例代码,觉得挺不错的,现在分享给大家,也给大家做个参考。 前言因为计算机数字是浮点型,所以在计算过程中通常得到的并不是一个准确的数据...
收集整理的这篇文章主要介绍了js加减乘除精确运算方法实例代码,觉得挺不错的,现在分享给大家,也给大家做个参考。

前言

因为计算机数字是浮点型,所以在计算过程中通常得到的并不是一个准确的数据,所以在做一些数组运算的时候比较头疼,我们这里就来写一下精确运算的方法

首先是加法 (这里以两个数据相加为例)

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加减乘除精确运算内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

您可能感兴趣的文章:
  • javascript解决小数的加减乘除精度丢失的方案
  • html+js实现简单的计算器代码(加减乘除)
  • js加减乘除丢失精度问题解决方法
  • 详解js加减乘除精确计算
  • JS实现的加减乘除四则运算计算器示例
  • js精确的加减乘除实例
  • javascript加减乘除的简单实例
  • 超级简易的JS计算器实例讲解(实现加减乘除)

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

上一篇: JavaScript/TypeScript 实现并发...下一篇:nodejs中的异步编程知识点详解猜你在找的JavaScript相关文章 html font标签如何设置字体大小?html font标签属性用法介绍2022-05-16vue3+TypeScript+vue-router的使用方法2022-04-16vue3获取当前路由地址2022-04-16如何利用React实现图片识别App2022-04-16JavaScript展开运算符和剩余运算符的区别详解2022-04-16微信小程序中使用vant框架的具体步骤2022-04-16Vue elementUI表单嵌套表格并对每行进行校验详解2022-04-16如何利用Typescript封装本地存储2022-04-16微信小程序中wxs文件的一些妙用分享2022-04-16JavaScript的Set数据结构详解2022-04-16 其他相关热搜词更多phpjavapython程序员loadpost-format-gallery

若转载请注明出处: js加减乘除精确运算方法实例代码
本文地址: https://pptw.com/jishu/594115.html
c语言如何定义字符串数组 c语言打印九九乘法表

游客 回复需填写必要信息