其实蛮容易实现的,关键是简洁与否,下面是我自己写的。
function randomSort(a){ var arr = a, random = [], len = arr.length; for (var i = 0; i < len; i++) { var index = Math.floor(Math.random()*(len - i)); random.push(a[index]); arr.splice(index,1); } return random; } var a = [1,2,3,4,5,6,7,8,9,10]; console.log(randomSort(a));
网上搜了下,有更简洁的,是用数组的sort方法,代码如下:
function randomsort(a, b) { return Math.random()>.5 ? -1 : 1; } var arr = [1, 2, 3, 4, 5]; arr.sort(randomsort);
通过随机产生0到1的数,然后判断是否大于0.5从而影响排序,产生随机性的效果。
上面我们测试的时候都是用纯数字的数组元素测试的,当然数组元素可以是字符串,也可以是对象,都是可以排序的。
不过有个问题,不管是我的方法还是那个牛人的方法,随机排序之后,原数组都变掉了,这个是要注意的。虽然我的方法里面有这么一句:var arr = a,但实际上这里的arr只是对数组a的引用,arr改变了,a也会改变。
要解决这个问题也不难,可以对数组进行拷贝,有深拷贝和浅拷贝什么的,这个大家可以去网上搜一下。具体看用处了,如果实在不需要原数组的话没必要多此一举了。