前端日常开发常用功能系列之乱序
这是前端日常开发常用功能这个系列文章的第一篇,该系列是日常开发中一些常用的功能的再总结、再提炼,以防止遗忘,便于日后复习。该系列预计包含以下内容: 防抖、节流、去重、拷贝、最值、扁平、乱序、排序、偏函数、柯里、惰性函数、递归、相等、注入、上传、下载、截图。。。
乱序就是断乱一组项目的顺序,显而易见
方法一:
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方法,平台差异性较小
其实这两种方法都是可以使用的。