js实现数组内元素随机排序

其实蛮容易实现的,关键是简洁与否,下面是我自己写的。

复制代码
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也会改变。

要解决这个问题也不难,可以对数组进行拷贝,有深拷贝和浅拷贝什么的,这个大家可以去网上搜一下。具体看用处了,如果实在不需要原数组的话没必要多此一举了。

参考资料:http://fp-moon.iteye.com/blog/1004419

原文地址:https://www.cnblogs.com/Im-Victor/p/13441387.html