JavaScript学习笔记:数组随机排序
特别声明:如果您喜欢小站的内容,可以点击申请会员进行全站阅读。如果您对付费阅读有任何建议或想法,欢迎发送邮件至: airenliao@gmail.com!或添加QQ:874472854(^_^)
JavaScript中提供了sort()
和reverse()
方法对数组项重新排序。但很多时候这两个方法无法满足我们实际业务的需求,比如说扑克牌游戏中的随机洗牌。
在这篇文章一起来学习如何完成上面这个示例的效果,以及一些有关于数组随机排序的相关知识。
在网上查了一下有关于数组随机排序的相关资料,都看到了Math.random()
的身影。打开浏览器控制器,输入:
Math.random()
有关于JavaScript随机数相关介绍,可以阅读《Math.random()随机数的二三事》一文。
从图中可以看出Math.random()
得到的是0~1
之间的随机数。众所周知,sort()
可以调用一个函数做为参数,如果这个函数返回的值为-1
表示数组中的a
项排在b
项前。如此一来,可以写一个随机函数,让Math.random()
随机出来的数与0.5
做为一个比较,如果大于.5
就返回 -1
(a
排在b
前面),反之返回1
(b
排在a
前面):
function randomSort(a, b) {
return Math.random() > 0.5 ? -1 : 1;
}
看个示例:
var arr = [1,2,3,4,5,6,7,8,9];
arr.sort(randomSort);
这样一来,就可以实现文章开头的示例效果:
虽然前面的方法实现了数组的随机排序,但总感觉每个元素被派到新数组的位置不是随机的。就如前面的示例,数组arr
中值为1
的元素,它的原先