递归,简单解释就是在函数内部调用自身,一定要有一个条件退出,不然的话就进入了死循环了。
1、首先要定义一个数组用来存放随机数
2、定义一个变量,并生成随机数
3、判断如果数组里面的随机数和新生成的随机数不重复就push进去,否则就重新生成随机数
开始写代码:
<script>
let arr = [];
function RandomArr(num, min, max) {
// 退出条件
if(num <=0) return arr;
// 生成指定范围内的随机数(包含最大值)
let randomNum = Math.floor(Math.random() * (max - min + 1)) + min;
// 如果数组里没有当前生成的随机数就添加进去,否则重新生成,num要减掉1,不然数组长度会不对
arr.indexOf(randomNum) === -1 ? arr.push(randomNum) : num++;
// 重复调用自身,num要-1 不然的话会达不到退出条件陷入死循环
return RandomArr(num-1, min, max);
}
RandomArr(6, 3, 44); // 数组长度为6,且元素在3-44之间
</script>