JS随机数功能详解

目录

一、Math.random()函数

二、生成指定范围内的随机整数

三、生成指定范围内的随机浮点数

四、生成指定范围内的随机布尔值


JavaScript中的随机功能可以通过Math对象提供的各种数学函数来实现。其中最常用的是Math.random()函数,它可以返回一个介于0和1之间的随机小数。

一、Math.random()函数

Math.random()函数返回一个介于0(包含)和1(不包含)之间的伪随机数。该函数不接受任何参数,每次调用都会返回一个新的随机数。

例如:

javascript 复制代码
var randomNumber = Math.random(); // 返回一个介于0和1之间的随机小数
console.log(randomNumber); // 输出类似于0.3456789

二、生成指定范围内的随机整数

有时候我们需要生成一个指定范围内的随机整数,比如从1到100之间。这时可以使用以下方法:

1.使用Math.floor()函数向下取整

javascript 复制代码
function getRandomInt(min, max) { 
return Math.floor(Math.random() * (max - min + 1)) + min; 
}
var randomNumber = getRandomInt(1, 100); // 返回一个介于1和100之间的随机整数 console.log(randomNumber); // 输出类似于42

该方法的原理是先通过Math.random()函数生成一个介于0和1之间的随机小数,然后将其乘以所需范围的大小,再加上最小值,最后使用Math.floor()函数向下取整。这样可以确保生成的随机数在指定范围内。

2.使用Math.random()函数结合条件语句

javascript 复制代码
function getRandomInt(min, max) { 
return Math.floor(Math.random() * (max - min + 1)) + min; 
} 
var randomNumber = Math.random() < 0.5 ? getRandomInt(1, 100) : getRandomInt(101, 200); 
//返回一个介于1和100之间或101和200之间的随机整数 console.log(randomNumber); // 输出类似于42或156

该方法的原理是先通过Math.random()函数生成一个介于0和1之间的随机小数,然后判断其是否小于0.5,如果是则调用getRandomInt(1, 100)函数生成一个介于1和100之间的随机整数,否则调用getRandomInt(101, 200)函数生成一个介于101和200之间的随机整数。这样可以确保生成的随机数在指定范围内。

三、生成指定范围内的随机浮点数

有时候我们需要生成一个指定范围内的随机浮点数,比如从1到10之间。这时可以使用以下方法:

javascript 复制代码
function getRandomFloat(min, max) {
return Math.random() * (max - min) + min; 
} 
var randomNumber = getRandomFloat(1, 10); // 返回一个介于1和10之间的随机浮点数 console.log(randomNumber); // 输出类似于3.456789

该方法的原理与生成指定范围内的随机整数类似,只是将最大值减去最小值再加1改为直接相减即可。这样可以确保生成的随机数在指定范围内。需要注意的是,由于使用了Math.random()函数,因此生成的浮点数可能会有一些微小的误差。如果需要更精确的浮点数,可以使用其他方法进行实现。

四、生成指定范围内的随机布尔值

有时候我们需要生成一个指定范围内的随机布尔值,比如true或false。这时可以使用以下方法:

javascript 复制代码
function getRandomBoolean() { 
return Math.random() < 0.5; 
// 生成一个介于0和1之间的随机小数,然后判断其是否小于0.5,如果是则返回true,否则返回false。
} var randomBoolean = getRandomBoolean(); 
// 返回一个true或false的随机布尔值 console.log(randomBoolean); // 输出类似于true或false

该方法的原理非常简单,只需要通过Math.random()函数生成一个介于0和1之间的随机小数,然后判断其是否小于0.5即可。这样可以确保生成的随机布尔值在指定范围内。需要注意的是,由于使用了Math.random()函数,因此每次生成的布尔值都是不确定的。如果需要固定的布尔值,可以直接使用true或false进行赋值。

相关推荐
大波V5几秒前
设计模式-参考的雷丰阳老师直播课
java·开发语言·设计模式
神夜大侠4 分钟前
VUE 实现公告无缝循环滚动
前端·javascript·vue.js
明辉光焱7 分钟前
【Electron】Electron Forge如何支持Element plus?
前端·javascript·vue.js·electron·node.js
无敌最俊朗@14 分钟前
unity3d————接口基础知识点
开发语言·c#
柯南二号40 分钟前
HarmonyOS ArkTS 下拉列表组件
前端·javascript·数据库·harmonyos·arkts
一丝晨光40 分钟前
gcc 1.c和g++ 1.c编译阶段有什么区别?如何知道g++编译默认会定义_GNU_SOURCE?
c语言·开发语言·c++·gnu·clang·gcc·g++
南城花随雪。1 小时前
Spring框架之装饰者模式 (Decorator Pattern)
java·开发语言·装饰器模式
前端郭德纲1 小时前
ES6的Iterator 和 for...of 循环
前端·ecmascript·es6
究极无敌暴龙战神X1 小时前
前端学习之ES6+
开发语言·javascript·ecmascript
欲游山河十万里1 小时前
(02)ES6教程——Map、Set、Reflect、Proxy、字符串、数值、对象、数组、函数
前端·ecmascript·es6