zoukankan      html  css  js  c++  java
  • 前端日常开发常用功能系列之乱序

    这是前端日常开发常用功能这个系列文章的第一篇,该系列是日常开发中一些常用的功能的再总结、再提炼,以防止遗忘,便于日后复习。该系列预计包含以下内容: 防抖、节流、去重、拷贝、最值、扁平、乱序、排序、偏函数、柯里、惰性函数、递归、相等、注入、上传、下载、截图。。。

    乱序就是断乱一组项目的顺序,显而易见

    方法一:

    function shuffle(arr) {
            const temp = JSON.parse(JSON.stringify(arr));
            return arr.sort(() => Math.random() - 0.5);
        }

    这个方法依赖于Math.random和数组的sort方法的实现,由于数组的sort方法的实现具有浏览器差异,其实得到的结果具有平台差异性

    方法二:

    function shuffle(arr) {
            const temp = JSON.parse(JSON.stringify(arr));
            for(let i = temp.length; i; i--) {
                let j = Math.floor(Math.random() * i);
                [temp[i - 1], temp[j]] = [temp[j], temp[i - 1]];
            }
            return temp;
        }

    这个方法的思想:遍历数组,遍历中每一项和随机一项交换位置;这种方法只依赖于Math.random方法,平台差异性较小

    其实这两种方法都是可以使用的。

  • 相关阅读:
    联考20200725 T1 String
    联考20200723 T1 数
    联考20200722 T3 积木
    联考20200722 T2 ACT4!无限回转!
    联考20200722 T1 集合划分
    联考20200721 T2 s2mple
    联考20200721 T1 s1mple
    联考20200719 T2 寻找规律
    联考20200719 T1 合并奶牛
    联考20200718 T2 树论
  • 原文地址:https://www.cnblogs.com/innooo/p/10442976.html
Copyright © 2011-2022 走看看