解决前端精度问题的JS库-math.js

JS的加减乘除算
1、加法算术:0.1+0.2

console.log(0.1+0.2);
	结果是:0.30000000000000004
复制代码

2、减法算术:0.8-0.7

console.log(0.8-0.7)
	结果是:0.10000000000000009
复制代码

3、乘法算术:5.10*100

	console.log(5.10*100)
	结果是:509.99999999999994
复制代码

4、除法法算术 6.10/0.1

console.log(6.10/0.1)
	结果是:60.99999999999999
复制代码

JavaScript 浮点数运算结果不对,是因为浮点数的存储问题导致计算结果不对。

Math.js
Math.js是一个用于JavaScript和Node.js的扩展数学库。它具有支持符号计算的灵活表达式解析器,大量内置函数和常量,并提供了集成的解决方案来处理不同的数据类型,例如数字,大数,复数,分数,单位和矩阵,强大且易于使用。

代码库:github.com/josdejong/m…
文档:mathjs.org/docs/index.…

特征
支持数字,大数,复数,分数,单位,字符串,数组和矩阵。
与JavaScript的内置Math库兼容,Math用法,一样,门槛低
包含一个灵活的表达式解析器。
进行符号计算。
带有大量内置函数和常量。
也可以用作命令行应用程序。
在任何JavaScript引擎上运行。
很容易扩展。
开源。
帮助使用教程:
1、传统使用,引入math.js

 <!DOCTYPE HTML>
    <html>
    <head>
      <script src="https://unpkg.com/mathjs@7.0.1/dist/math.min.js" type="text/javascript"></script>
    </head>
    <body>
      <script type="text/javascript">
        const ans = math.add(0.1, 0.2)     //  0.30000000000000004
        console.log(math.format(ans, {precision: 14})) // '0.3'
        console.log(math.sqrt(4).toString()) // 2
      </script>
    </body>
    </html>
复制代码

2、es module

npm安装

npm install mathjs
复制代码

使用

import { create, all } from 'mathjs'
const config = { 
  number: 'BigNumber',
  precision: 20
}
const math = create(all, config);
export default {
  methods: {
  	//开方
    numberSqrt: function(arg1){
    	return math math.sqrt(arg1)
    },
    //
    numberExcept: function (arg1, arg2) {
      return math.divide(arg1, arg2);
    },
    //
    numberRide: function (arg1, arg2) {      
      return math.multiply(arg1, arg2);
    },
    //
    numberAdd:function (arg1,arg2) {
    return math.add(arg1, arg2);
    }
    //
    numberSub:function (arg1,arg2) {
    return math.add(arg1, -arg2);
    }
  }
}
复制代码

math.js 常用数学功能

<script type="text/javascript">
    // expressions
    console.log(math.evaluate('1.2 * (2 + 4.5)')) // 7.8
    console.log(math.evaluate('12.7 cm to inch')) // 5 inch
    console.log(math.evaluate('sin(45 deg) ^ 2')) // 0.5
    console.log(math.evaluate('9 / 3 + 2i')) // 3 + 2i
    console.log(math.evaluate('det([-1, 2; 3, 1])')) // -7
    
    // mixed use of different data types in functions
    console.log(math.add(5, [9, 6])) // number + Array, [14, 11]
    console.log(math.multiply(math.unit('5 mm'), 3)) // Unit * number,  15 mm
    console.log(math.subtract([2, 3, 4], 10)) // Array - number, [-8, -7, -6]
    console.log(math.add(math.matrix([4, 1]), [2, 9])) // Matrix + Array, [6, 10]	
    
    // chain operator
    console.log(math.chain(3)
        .add(4)
        .subtract(2)
        .done()) // 5

	console.log(math.chain( [[1, 2], [3, 4]] )
        .subset(math.index(0, 0), 8)
        .multiply(3)
        .done()) // [[24, 6], [9, 12]]
</script>

最后
如果你觉得此文对你有一丁点帮助,点个赞。或者可以加入我的开发交流群:1025263163相互学习,我们会有专业的技术答疑解惑

如果你觉得这篇文章对你有点用的话,麻烦请给我们的开源项目点点star:http://github.crmeb.net/u/defu不胜感激 !

PHP学习手册:https://doc.crmeb.com
技术交流论坛:https://q.crmeb.com

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CRMEB定制开发

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值