Aimless.js API完全参考手册:所有函数用法和参数详解
Aimless.js API完全参考手册:所有函数用法和参数详解
【免费下载链接】aimless.jsThe missing JavaScript randomness library.项目地址: https://gitcode.com/gh_mirrors/ai/aimless.js
Aimless.js是JavaScript中缺失的随机性库,提供了丰富的随机数生成函数,满足各种随机数据需求。本文将详细介绍Aimless.js的所有API函数,帮助开发者快速掌握这个强大的随机数工具库。
核心函数概览
Aimless.js的核心功能通过src/aimless.ts文件统一导出,主要包含以下几类随机数生成函数:
- 基础随机值:
bool,char,sign - 数值范围:
intRange,floatRange - 概率分布:
normalDist,exponentialDist,customDist - 序列生成:
sequence,intSequence,uniqFuncSequence - 特殊功能:
oneOf,weighted,uuid
基础随机值生成
bool() - 随机布尔值
功能:生成随机布尔值(true或false)
参数:
engine: 可选,随机数引擎实例,默认为defaultEngine
示例:
import { bool } from 'aimless.js'; // 生成随机布尔值 const randomBool = bool(); console.log(randomBool); // 输出: true 或 false实现源码:src/bool.ts
char() - 随机字符
功能:生成随机字符,支持自定义字符集
参数:
chars: 可选,字符集字符串,默认为大小写字母和数字engine: 可选,随机数引擎实例,默认为defaultEngine
示例:
import { char } from 'aimless.js'; // 生成随机字母数字字符 const randomChar = char(); // 生成随机小写字母 const lowercaseChar = char('abcdefghijklmnopqrstuvwxyz');数值范围生成
intRange() - 整数范围随机数
功能:生成指定范围内的随机整数(包含边界值)
参数:
min: 必需,最小值max: 必需,最大值engine: 可选,随机数引擎实例,默认为defaultEngine
示例:
import { intRange } from 'aimless.js'; // 生成1-10之间的随机整数 const randomInt = intRange(1, 10); console.log(randomInt); // 输出: 3 (示例)实现源码:src/int-range.ts
floatRange() - 浮点数范围随机数
功能:生成指定范围内的随机浮点数
参数:
min: 必需,最小值max: 必需,最大值precision: 可选,小数位数,默认为2engine: 可选,随机数引擎实例,默认为defaultEngine
示例:
import { floatRange } from 'aimless.js'; // 生成0-1之间的随机浮点数 const randomFloat = floatRange(0, 1); // 生成10-20之间保留4位小数的随机浮点数 const preciseFloat = floatRange(10, 20, 4);概率分布生成
normalDist() - 正态分布随机数
功能:生成符合正态分布的随机数
参数:
mean: 可选,均值,默认为0stddev: 可选,标准差,默认为1engine: 可选,随机数引擎实例,默认为defaultEngine
示例:
import { normalDist } from 'aimless.js'; // 生成标准正态分布随机数 const normalValue = normalDist(); // 生成均值为50,标准差为10的正态分布随机数 const customNormal = normalDist(50, 10);exponentialDist() - 指数分布随机数
功能:生成符合指数分布的随机数
参数:
lambda: 可选,率参数,默认为1engine: 可选,随机数引擎实例,默认为defaultEngine
示例:
import { exponentialDist } from 'aimless.js'; // 生成率参数为0.5的指数分布随机数 const expValue = exponentialDist(0.5);序列与集合操作
sequence() - 随机序列生成
功能:生成包含随机值的序列数组
参数:
length: 必需,序列长度generator: 必需,生成每个元素的函数engine: 可选,随机数引擎实例,默认为defaultEngine
示例:
import { sequence, intRange } from 'aimless.js'; // 生成包含5个1-100随机整数的序列 const randomSequence = sequence(5, () => intRange(1, 100));oneOf() - 从数组中随机选择
功能:从数组中随机选择一个元素
参数:
array: 必需,源数组engine: 可选,随机数引擎实例,默认为defaultEngine
示例:
import { oneOf } from 'aimless.js'; const fruits = ['apple', 'banana', 'orange', 'grape']; // 随机选择一个水果 const randomFruit = oneOf(fruits);weighted() - 加权随机选择
功能:根据权重从数组中随机选择元素
参数:
options: 必需,包含value和weight属性的对象数组engine: 可选,随机数引擎实例,默认为defaultEngine
示例:
import { weighted } from 'aimless.js'; const options = [ { value: 'A', weight: 1 }, { value: 'B', weight: 2 }, { value: 'C', weight: 3 } ]; // 按权重随机选择(C被选中的概率最高) const selected = weighted(options);特殊功能
uuid() - 生成UUID
功能:生成符合RFC4122标准的UUID v4
参数:
engine: 可选,随机数引擎实例,默认为defaultEngine
示例:
import { uuid } from 'aimless.js'; // 生成随机UUID const id = uuid(); console.log(id); // 输出: "a1b2c3d4-5678-90ef-ghij-klmnopqrstuv"seedFunc() - 种子函数生成
功能:创建可复现的随机数生成函数
参数:
seed: 必需,种子值
示例:
import { seedFunc, intRange } from 'aimless.js'; // 创建种子随机数引擎 const seededEngine = seedFunc(12345); // 使用种子引擎生成可复现的随机数 const firstRun = intRange(1, 100, seededEngine); // 重置引擎后会得到相同的结果 seededEngine.reset(); const secondRun = intRange(1, 100, seededEngine); console.log(firstRun === secondRun); // 输出: true带引擎的函数变体
Aimless.js中的大多数函数都提供了WithEngine后缀的变体(如boolWithEngine、intRangeWithEngine),这些函数允许你创建绑定到特定引擎的生成器函数:
示例:
import { intRangeWithEngine, seedFunc } from 'aimless.js'; // 创建绑定到特定种子引擎的整数生成器 const seededIntRange = intRangeWithEngine(seedFunc(9876)); // 后续调用无需再指定引擎 const number1 = seededIntRange(1, 10); const number2 = seededIntRange(1, 10);安装与使用
要开始使用Aimless.js,首先需要克隆仓库:
git clone https://gitcode.com/gh_mirrors/ai/aimless.js cd aimless.js npm install然后在你的项目中导入所需的函数:
import { intRange, normalDist, oneOf } from 'aimless.js';总结
Aimless.js提供了全面的随机数生成解决方案,从简单的布尔值到复杂的概率分布,从基础的数值生成到高级的序列操作。通过本文介绍的API,你可以轻松实现各种随机数据需求。无论是游戏开发、数据分析还是模拟测试,Aimless.js都能成为你可靠的随机数工具库。
更多详细信息和高级用法,请参考项目的测试文件:test/index.js。
【免费下载链接】aimless.jsThe missing JavaScript randomness library.项目地址: https://gitcode.com/gh_mirrors/ai/aimless.js
创作声明:本文部分内容由AI辅助生成(AIGC),仅供参考
