LOGO OA教程 ERP教程 模切知识交流 PMS教程 CRM教程 开发文档 其他文档  
 
网站管理员

[点晴永久免费OA]Math.js:一款 JavaScript 和 Node.js 最强数学库

freeflydom
2023年12月28日 10:37 本文热度 703

前段时间有个同学问了我一个需求:如何在一个椭圆上均匀放置任意多的DOM。需求效果如下

我一看这个需求,这不得用到"传说"中的初中数学了吗?然后我“掐指一算”还真给忘完了...

没得办法,只能去翻了翻“初中课本”,找到了椭圆计算的方式,最终写了如下代码:

<!DOCTYPE html>

<html>


<head>

<meta charset="UTF-8">

<title>Icons on Ellipse</title>

<style>

canvas {

border: 1px solid black;

}

</style>

</head>


<body>

<canvas id="myCanvas" width="400" height="400"></canvas>

<script>

const canvas = document.getElementById('myCanvas');

const ctx = canvas.getContext('2d');


const centerX = canvas.width / 2;

const centerY = canvas.height / 2;

const a = 150; // 长轴

const b = 100; // 短轴

const iconRadius = 8; // 图标半径

const numberOfIcons = 10; // 图标数量


ctx.fillStyle = 'blue';


for (let i = 0; i < numberOfIcons; i++) {

const angle = (Math.PI * 2) * (i / numberOfIcons);

const x = centerX + a * Math.cos(angle);

const y = centerY + b * Math.sin(angle);


// 在计算的坐标处绘制圆形图标

ctx.beginPath();

ctx.arc(x, y, iconRadius, 0, Math.PI * 2);

ctx.fill();

}

</script>

</body>


</html>


通过这样的代码实现了椭圆均匀分布的效果:

不过,做过多年开发的同学都知道,数学这种东西,真的挺容易忘的。所以说,我专门去翻了翻 Github 找到了一个专业的扩展数据库,它就是:Math.js

01:什么是 Math.js

Math.js 是一个适用于 JavaScript 和 Node.js 的扩展数学库,支持符号计算,并提供了广泛的功能,涵盖数字、大数字、复数、分数、单位和矩阵等多种数据类型。它与JavaScript内置数学库兼容,适用于各类ES6兼容的JavaScript引擎,如Node.js、Chrome、Firefox、Safari和Edge等。

Math.js的主要特性包括:

  • 支持多种数据类型,包括数字、大数字、复数、分数、单位、字符串、数组和矩阵。

  • 与JavaScript内置数学库兼容。

  • 强大的表达式解析器和符号计算支持。

  • 内置丰富的函数和常量。

  • 可作为命令行应用程序使用。

  • 可在任何JavaScript引擎上运行。

  • 易于扩展且完全开源。

目前,Math.js在GitHub上采用MIT许可协议开源,拥有超过13.7k的星标、1.3k的分支、63.8k的项目依赖量以及来自200多位贡献者的代码贡献。是一个备受推崇的优质前端开源项目。

02:为什么需要 Math.js

Math.js的目标在于提供一个环境,让开发者能够使用混合数据类型进行计算,比如将普通数字与复数或BigNumber相乘,以及对矩阵中的各种数据进行处理。它还允许轻松添加新的数据类型,比如BigInt。

Math.js采用了两个核心解决方案:

  1. 类型化函数(Typed functions):所有函数都利用typed-function创建,这使得动态创建和扩展单个函数以及自动对函数输入进行类型转换变得更加简单。比如,可以通过支持两个BigInt相乘来扩展乘法函数。如果定义了从BigInt到数字的转换,typed-function会自动允许BigInt与数字相乘。

  2. 依赖注入(Dependency injection):当有一个支持BigInt的multiply函数时,由于依赖注入,其他在底层使用multiply的函数也将自动支持BigInt,反之亦然。如果只需要简单的数字支持,不需要过重的multiply(支持BigNumbers、矩阵等),可以使用仅用于数字的轻量级multiply实现,并将其注入到prod和其他函数中。

在底层,mathjs采用了不可变函数的不可变工厂函数。核心函数math.create(...)用于创建一个新实例,包含从传递的所有工厂函数创建的函数。mathjs实例是创建函数的集合。它还包含像math.import这样的函数,允许使用新函数扩展实例,然后可以在表达式解析器中使用。

03:如何使用 Math.js

Math.js是一个多功能的库,可在Node.js和浏览器环境中使用。它类似于JavaScript的内置Math库,但更进一步,支持表达式计算和链式操作。

// 使用函数和常量

math.round(math.e, 3); // 得到2.718

math.atan2(3, -3) / math.pi; // 返回0.75

math.log(10000, 10); // 输出4

math.sqrt(-4); // 返回2i

math.pow(

  [

    [-1, 2],

    [3, 1],

  ],

  2

); // 得到[[7, 0], [0, 7]]


// 表达式计算

math.evaluate('12 / (2.3 + 0.7)'); // 返回4

math.evaluate('12.7 cm to inch'); // 输出5 inch

math.evaluate('sin(45 deg) ^ 2'); // 得到0.5

math.evaluate('9 / 3 + 2i'); // 返回3 + 2i

math.evaluate('det([-1, 2; 3, 1])'); // 输出-7


// 链式操作

math.chain(3).add(4).multiply(2).done(); // 返回14


这些例子展示了Math.js的灵活性,无论是进行基本数学运算、处理单位转换还是进行复杂的矩阵计算,都能轻松应对。而链式操作则允许你连续调用多个函数,简洁地处理多步计算。


作者:程序员Sunday
链接:https://juejin.cn/post/7315630639797125139
来源:稀土掘金
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。



该文章在 2023/12/28 10:37:16 编辑过
关键字查询
相关文章
正在查询...
点晴ERP是一款针对中小制造业的专业生产管理软件系统,系统成熟度和易用性得到了国内大量中小企业的青睐。
点晴PMS码头管理系统主要针对港口码头集装箱与散货日常运作、调度、堆场、车队、财务费用、相关报表等业务管理,结合码头的业务特点,围绕调度、堆场作业而开发的。集技术的先进性、管理的有效性于一体,是物流码头及其他港口类企业的高效ERP管理信息系统。
点晴WMS仓储管理系统提供了货物产品管理,销售管理,采购管理,仓储管理,仓库管理,保质期管理,货位管理,库位管理,生产管理,WMS管理系统,标签打印,条形码,二维码管理,批号管理软件。
点晴免费OA是一款软件和通用服务都免费,不限功能、不限时间、不限用户的免费OA协同办公管理系统。
Copyright 2010-2025 ClickSun All Rights Reserved