js数组打乱顺序

网上有很多数组排序的,但是我觉得没必要那么复杂,搞个最优的,然后描述清楚让大家理解明白就好了
/**
     * 打乱数组顺序
     * @param arr
     * @returns {*}
     *  
     */
     
    randomArr(arr){
        let length= arr.length;
        //while执行至条件不成立则跳出循环
        while(length > 1){
            // --length 先自减再执行表达式
            // length-- 先执行表达式再自减
            //length 先执行random和floor得到index后再自减
            let index = Math.floor(Math.random() * length--);
            //es6的解构赋值,等号的左右两边模式相同,就会将右边的值赋给左边的变量
            [arr[length], arr[index]] = [arr[index], arr[length]];
        }
        return arr;
    },

while里面不建议加console等其它无逻辑无关的东西,以免导致排序不执行

如果此文对你有用请动动你的小手点个赞!谢谢!!!

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 网上有很多数组排序的,但是我觉得没必要那么复杂,搞个最优的,然后描述清楚让大家理解明白就好了,还写什么sort()...
    前端_酒館阅读 619评论 0 1
  • 1.sort 排序letarray=[1,2,3,4,21,2,333,12,33,44,55,1,2,3,4,5...
    不忘初心_3c70阅读 190评论 0 0
  • 冒泡排序 思路:重复遍历数组中的元素,依次比较两个相邻的元素,如果前一个元素大于后一个元素,就依靠第三个变量将它们...
    晴天的晴q阅读 2,842评论 0 1
  • 数组排序在日常编程中用到的其实还是比较多的,比如把一组数据按时间排序,按首字母排序,按大小排序等等,那么就让我们一...
    一木_qintb阅读 13,132评论 1 2
  • 数组排序在日常编程中用到的其实还是比较多的,比如把一组数据按时间排序,按首字母排序,按大小排序等等,那么就让我们一...
    xueNoble阅读 2,179评论 0 9