做云课堂的作业时遇到一要求,实现刷新页面时显示不同数据,(数组中20个据,页面加载10个)。思路就是从0-19中随机生成10个不同的数,让数组取下标输出数据。
下面是在num的范围内生成n个不重复的数。例如从10以内随机生成5个不同的数randomNum(10,5);
function randomNum(num,n) { if(typeof num!=="number"||typeof n!=="number") return false; //对象检测 var aNum=[]; if (num<=n) { for (var j = 0; j < num; j++) { aNum.push(j); }; return aNum; } //如果n大于num就生成0到num-1的每一个数 else{ for (var i = 0; i < num; i++) { var random=Math.round(Math.random()*num); if (aNum.indexOf(random)==-1) { aNum.push(random); if (aNum.length==n) { return aNum; }; } } } } //从0至num-1中随机获得n个不同的数的数组
上面这个有重大bug,谢谢评论区大神提醒,改进如下:
function randomNum(num,n) { if(typeof num!=="number"||typeof n!=="number") return false; //对象检测 var aNum=[]; if (num<=n) { for (var j = 0; j < num; j++) { aNum.push(j); }; return aNum; } //如果n大于num就生成0到num-1的每一个数 else{ while(aNum.length<n){ var random=Math.round(Math.random()*num); if (aNum.indexOf(random)==-1) { aNum.push(random); } } return aNum; } }