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方法,平台差异性较小

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

  • 相关阅读:
    instanceof方法
    Java 实现接口计算圆柱的体积和面积并添加颜色
    Java代码执行顺序
    Java饿汉单例模式
    斐波那契数(动态规划和递归)
    Java 接口实现计算器加减乘除(字符交互界面)
    局部内部类详解_转载
    Java引用类型
    递归打印字符串
    时间复杂度
  • 原文地址:https://www.cnblogs.com/innooo/p/10442976.html
Copyright © 2011-2022 走看看