JavaScript中生成不同类型与范围随机数的多种技巧汇总

网络 2024-08-06 18:12:49编程技术
531

JavaScript 是一种功能强大的编程语言,广泛应用于网页开发、游戏制作和各种计算任务中。生成随机数是编程中的一个常见需求,无论是在开发简单的浏览器游戏、进行数据模拟,还是在安全性要求较高的场景中,掌握如何生成不同类型与范围的随机数都是至关重要的。本文将深入探讨 JavaScript 中生成随机数的各种技巧,从基本的Math.random()函数到更高级的算法,帮助读者全面了解并掌握这一核心技能。

Javascript.jpg

1,生成 [ 0, 1 ) 范围内的随机数(大于等于0,小于1)

(1)使用 random() 方法可以返回一个介于 0 ~ 1 之间的伪随机数(包括 0,不包括 1)。

Math.random()

(2)下面是一个测试样例

var random = Math.random();
console.log(random);

2,生成 [ n, m ) 范围内的随机数(大于等于n,小于m)

(1)这种最简单,因为和 random 的特点保持一致。只需使用如下公式即可:

Math.random()*(m-n)+n

(2)比如下面生成 [10,15) 范围内的随机浮点数。

var random1 = Math.random()*(15-10)+10;
var random2 = Math.random()*(15-10)+10;
var random3 = Math.random()*(15-10)+10;
console.log(random1);
console.log(random2);
console.log(random3);

3,生成 [n,m]、(n,m)、(n,m] 范围内的随机数

因为 random 的特点,要取得这几个区间内的浮点数稍微麻烦些,需要借助一些判断才能满足要求。

//取得[n,m]范围随机数
function fullClose(n,m) {
   var result = Math.random()*(m+1-n)+n;
   while(result>m) {
       result = Math.random()*(m+1-n)+n;
   }
   return result;
}
 
//取得(n,m)范围随机数
function fullOpen(n,m) {
   var result = Math.random()*(m-n)+n;
   while(result == n) {
       result = Math.random()*(m-n)+n;
   }
   return result;
}
 
//取得(n,m]范围随机数
function leftOpen(n,m) {
   var result = Math.random()*(m-n+1)+n-1;
   while(result<n) {
       result = Math.random()*(m-n+1)+n-1;
   }
   return result;
}

随机整数的生成

要生成随机整数,我们还需要借助如下两个方法: Math.round(num):将 num 四舍五入取整 Math.floor(num):将 num 向下取整,即返回 num 的整数部分。当然我们也可以使用 parseInt() 方法代替。

1,随机生成 0、1 这两个整数

(1)下面这个方法可以随机获取 0 或 1,它们获取到的几率是比较均衡的。

Math.round(Math.random())

(2)下面是一个测试样例

var random1 = Math.round(Math.random());
var random2 = Math.round(Math.random());
var random3 = Math.round(Math.random());
console.log(random1);
console.log(random2);
console.log(random3);

2,生成 [ 0, n ) 范围内的随机整数(大于等于0,小于n)

(1)下面方法生成一个 0 到 n-1 的随机整数(这 n 个数获取几率都是均衡的)

Math.floor(Math.random()*n)

(2)比如下面生成几个 0 到 4 的随机整数(包括 0 和 4)。

var random1 = Math.floor(Math.random()*5);
var random2 = Math.floor(Math.random()*5);
var random3 = Math.floor(Math.random()*5);
console.log(random1);
console.log(random2);
console.log(random3);

3,生成 [ 1, n ] 范围内的随机整数(大于等于1,小于等于n)

(1)下面方法生成一个 1 到 n 的随机整数(这 n 个数获取几率都是均衡的)

Math.floor(Math.random()*n)+1

(2)比如下面生成几个 1 到 5 的随机整数(包括 1 和 5)。

var random1 = Math.floor(Math.random()*5)+1;
var random2 = Math.floor(Math.random()*5)+1;
var random3 = Math.floor(Math.random()*5)+1;
console.log(random1);
console.log(random2);
console.log(random3);

4,生成 [ min, max ] 范围内的随机整数(大于等于min,小于等于max)

(1)下面方法生成一个最小值为 min,最大值为 max 的随机整数。

Math.floor(Math.random()*(max-min+1))+min

(2)比如下面生成几个 5 到 10 的随机整数

var random1 = Math.floor(Math.random()*5)+1;
var random2 = Math.floor(Math.random()*5)+1;
var random3 = Math.floor(Math.random()*5)+1;
console.log(random1);
console.log(random2);
console.log(random3);

随机字符串的生成

1,生成指定位数的纯数字字符串

//生成n位数字字符串
function randomNum(n){
  var res = "";
  for(var i=0;i<n;i++){
    res += Math.floor(Math.random()*10);
  }
  return res;
}
 
//测试
console.log(randomNum(3))
console.log(randomNum(5))
console.log(randomNum(7))

2,生成指定位数的数字字母混合的字符串

//生成n位数字字母混合字符串
function generateMixed(n) {
  var chars = ['0','1','2','3','4','5','6','7','8','9',
              'A','B','C','D','E','F','G','H','I','J','K','L','M',
              'N','O','P','Q','R','S','T','U','V','W','X','Y','Z'];
  var res = "";
  for(var i = 0; i < n ; i++) {
     var id = Math.floor(Math.random()*36);
     res += chars[id];
  }
  return res;
}
 
//测试
console.log(generateMixed(3))
console.log(generateMixed(5))
console.log(generateMixed(7))

对比上面代码的补充版,加入 数字、大小写字符

function getjl(n){
var chas=["0","1","2","3","4","5","6","7","8","9","A","B","C","D","E","F","G","H","I","J","K","L","M","N","O","P","Q","R","S","T","U","V","W","X","Y","Z","a","b","c","d","e","f","g","h","i","j","k","l","m","n","o","p","q","r","s","t","u","v","w","x","y","z"];
var binint=["0","1","2","3","4","5","6","7","8","9"];
var res="";
for(var i=0; i < n; i++){
		var id = Math.floor(Math.random() * 62);
		res+=chas[id];
	}
						
return res;
}
//测试
console.log(getjl(3))
console.log(getjl(5))
console.log(getjl(7))

总结

通过本文的学习,我们深入了解了JavaScript中生成随机数的多种方法,包括生成不同范围的整数、浮点数以及符合特定分布的随机数。这些技巧不仅满足了常见的需求,也为解决复杂问题提供了有力工具。无论是用于游戏开发、数据分析还是其他需要随机性的应用场景,掌握这些方法都将使你的编程能力更加全面和强大。希望本文的内容能够为你的JavaScript编程之旅提供宝贵的帮助。

JavaScript 随机数 random
THE END
战地网
频繁记录吧,生活的本意是开心

相关推荐

JavaScript 中 instanceof 的作用及使用方法详解
在 JavaScript 的类型检查体系中,instanceof 是一个重要的操作符,用于判断一个对象是否属于某个构造函数的实例或其原型链上的类型。本文ZHANID工具网将系统讲解 instanceof...
2025-09-11 编程技术
503

JavaScript出现“undefined is not a function”错误的解决方法
在JavaScript开发中,TypeError: undefined is not a function 是最常见的运行时错误之一,通常表示代码尝试调用一个未定义(undefined)的值作为函数。本文ZHANID工具网将从...
2025-09-10 编程技术
518

JavaScript报错“Uncaught ReferenceError”如何解决?
在JavaScript开发中,“Uncaught ReferenceError”是常见且易混淆的错误类型。本文ZHANID工具网从错误本质、常见场景、排查步骤、解决方案四个维度,结合真实代码案例与调试技...
2025-09-09 编程技术
566

JavaScript面试题汇总:高频考点与答案解析
在前端开发领域,JavaScript作为核心语言,其面试题覆盖了从基础语法到高级特性的广泛范围。本文ZHANID工具网将系统梳理JavaScript高频面试考点,结合权威资料与典型案例,为...
2025-09-08 编程技术
478

JavaScript中严格模式(use strict)的作用与使用场景
JavaScript的灵活性既是其优势,也是开发者面临的挑战。非严格模式下,隐式全局变量、模糊的this绑定等特性容易导致难以调试的错误。为解决这些问题,ECMAScript 5(ES5)引入...
2025-09-04 编程技术
533

使用JavaScript开发一个简易计算器(附示例代码)
在Web开发领域,JavaScript因其灵活性和强大的交互能力成为实现动态功能的核心技术。本文ZHANID工具网将通过构建一个简易计算器,系统讲解如何利用HTML、CSS和JavaScript完成...
2025-09-03 编程技术
526