要想用js随机获取10个1~20之间的整数组成一个数组,这并不困难,但是这样获取出来的数字难免会有重复的,那么如何获取出一个不重复的数组呢。
js代码如下:
<body>
<p id="pid"></p>
<script>
var pid = document.getElementById('pid');
var arr = [];
for(var i=0;i<10;i++){
getx(arr);
}
function getx(arr){
for(var i=0;i>-1;i++){
var flag = true;
var num = Math.floor(Math.random()*20)+1;
for(var i in arr){
if(arr[i] == num){
flag= false;
break;
}
}
if(flag == true){
console.log(num);
arr.push(num);
return;
}
}
}
pid.innerHTML = arr;
</script>
思路如下:
我们封装一个函数,这个函数用来返回一个随机数。
首先,我们先来写一个死循环,在函数开始的时候设置一个flag,并且生成一个随机数,然后遍历一下数组,如果数组中已经存在这个随机数了,就把flag变成false,并且跳出遍历。跳出遍历或者等遍历完成之后判断一下flag的值,如果flag为true,就把这个数push进数组,并且return然后中断死循环,跳出循环,否则的话继续运行这个循环,直到得到一个数组中不存在的数字为止。
其实要实现这个功能有很多种思路啊,这只是博主自己一个人的思路,大家可以集思广益哦,肯定会有很大的收获