来自脚本之家
var count=3000;
var original=new Array; //原始数组
//给原始数组original赋值
for (var i=0;i<count;i++){
original[i]=i+1;
}
original.sort(function(){ return 0.5 - Math.random(); });
for (var i=0;i<count;i++){
console.log(original[i]+" ");
}
JavaScript的Math对象提供了random()方法,可以获取一个[0,1)的随机数,利用这个方法,取一个随机数容易,但要是取一个随机并且不重复的数,就需要绕点弯子
试着更换一下思路,获取随机数并不一定需要随机取得一个值,并前后判断是否重复,可以首先创建一个范围,并以该范围所有的值创建一个数组,将数组的排序随机,那么从该数组中按线性获取的值,不也就是随机不定的吗
且由于只是重新排列了数组,数组中永远不会出现重复的值,只需利用Array的sort()方法和Math.random()方法就可以实现获取随机不重复的功能
sort()方法:sort()用于数组,如果不传入参数,那么它会对数组的每一项调用toString()方法,再对每一个字符串进行比较排序(按照首字符的编码大小排序)
若传入参数,会按照参数的正负情况对每两个进行该方法的数组项排序。
无参的方法调用在升降排序number类型数据时并不好用,所以一般给sort()方法传入一个“比较”函数,以此为number类型的数组项升降排序
利用该方法的排序特性,随机这种排序就可以达到随机打乱数组的效果