zoukankan      html  css  js  c++  java
  • 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

  • 相关阅读:
    8. Java 异常
    9. GUI编程
    生成验证码
    使用response实现文件的下载
    关于小程序的几个坑
    关于redux应用
    关于修改react的启动端口
    react 坑总结
    关于小程序的一些坑的总结
    微信开发者工具 跨域问题
  • 原文地址:https://www.cnblogs.com/zmhaki/p/3223170.html
Copyright © 2011-2022 走看看