网上有很多数组排序的,但是我觉得没必要那么复杂,搞个最优的,然后描述清楚让大家理解明白就好了,还写什么sort()啥的,瞎鸡儿玩!!!
/**
* 打乱数组顺序
* @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等其它无逻辑无关的东西,以免导致排序不执行
如果此文对你有用请动动你的小手点个赞!谢谢!!!
网友评论