JS随机打乱数组的方法小结


Posted in Javascript onJune 22, 2016

本文实例总结了JS随机打乱数组的方法。分享给大家供大家参考,具体如下:

JS中,要打乱数组有很多方法,网上流传一个国外人写的方法,我认为是最精简的了:

function randomsort(a, b) {
    return Math.random()>.5 ? -1 : 1;
    //用Math.random()函数生成0~1之间的随机数与0.5比较,返回-1或1
}
var arr = [1, 2, 3, 4, 5];
arr.sort(randomsort);

这里介绍下sort()函数,在JS中Array对象里内置了一个函数:

arrayobj.sort([sortfunction])

此方法将 Array 对象进行适当的排序;在执行过程中并不会创建新的 Array 对象。

sortFunction为可选项。

是用来确定元素顺序的函数的名称。如果这个参数被省略,那么元素将按照 ASCII 字符顺序进行升序排列。

sortFunction方法有两个参数。分别代表每次排序比较时的两个数组项。sort()排序时每次比较两个数组项都回执行这个参数,并把两个比较的数组项作为参数传递给这个函数。当函数返回值为1的时候就交换两个数组项的顺序,否则就不交换。

我们可以对上面的randomsort()稍作修改,来实现升序排列和降序排列:

function asc(a,b) {
return a < b ? -1 : 1;//如果a<b不交换,否则交换,即升序排列
}
function desc(a,b) {
return a > b ? -1 : 1;;//如果a>b不交换,否则交换,即将序排列
}

另外,可以直接把一个无名函数直接放到sort()方法的调用中。如下的例子是将奇数排在前面,偶数排在后面,例子如下:

以下是引用片段:

var arrA = [6,2,4,3,5,1];
arrA.sort( function(x, y) {
if (x % 2 ==0) return 1;
if (x % 2 !=0) return -1;
});
document.writeln(arrA); //输出:1,5,3,4,6,2

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
图像替换新技术 状态域方法
Jan 28 Javascript
javascript中checkbox使用方法实例演示
Nov 19 Javascript
用jQuery获取table中行id和td值的实现代码
May 19 Javascript
js内置对象处理_打印学生成绩单的简单实现
Sep 24 Javascript
canvas压缩图片转换成base64格式输出文件流
Mar 09 Javascript
js实现返回顶部效果
Mar 10 Javascript
jQuery+ajax实现局部刷新的两种方法
Jun 08 jQuery
微信小程序多音频播放进度条问题
Aug 28 Javascript
vue.js中ref和$refs的使用及示例讲解
Aug 14 Javascript
vue使用自定义事件的表单输入组件用法详解【日期组件与货币组件】
Jun 01 Javascript
微信小程序以7天为周期连续签到7天功能效果的示例代码
Aug 20 Javascript
JavaScript实现点击切换功能
Jan 27 Javascript
JS产生随机数的几个用法详解
Jun 22 #Javascript
js与applet相互调用的方法
Jun 22 #Javascript
javascript时间戳和日期字符串相互转换代码(超简单)
Jun 22 #Javascript
JS 日期与时间戮相互转化的简单实例
Jun 22 #Javascript
静态页面html中跳转传值的JS处理技巧
Jun 22 #Javascript
浅谈JavaScript for循环 闭包
Jun 22 #Javascript
Javascript获取随机数的实现方法
Jun 22 #Javascript
You might like
php中看实例学正则表达式
2006/12/25 PHP
探讨:如何通过stats命令分析Memcached的内部状态
2013/06/14 PHP
php Session存储到Redis的方法
2013/11/04 PHP
js跳转页面方法总结
2014/01/29 Javascript
JavaScript中数据结构与算法(三):链表
2015/06/19 Javascript
javascript实现判断鼠标的状态
2015/07/10 Javascript
require简单实现单页应用程序(SPA)
2016/07/12 Javascript
jquery 判断selection range 是否在容器中的简单实例
2016/08/02 Javascript
vue如何实现observer和watcher源码解析
2017/03/09 Javascript
Node.js通过身份证号验证年龄、出生日期与性别方法示例
2017/03/09 Javascript
jquery中ajax请求后台数据成功后既不执行success也不执行error的完美解决方法
2017/12/24 jQuery
为什么使用koa2搭建微信第三方公众平台的原因
2018/05/16 Javascript
angular6.0使用教程之父组件通过url传递id给子组件的方法
2018/06/30 Javascript
在小程序开发中使用npm的方法
2018/10/17 Javascript
vue 验证两次输入的密码是否一致的方法示例
2020/09/29 Javascript
小程序实现点击tab切换左右滑动
2020/11/16 Javascript
[06:57]DOTA2-DPC中国联赛 正赛 Ehome vs PSG.LGD 选手采访
2021/03/11 DOTA
Centos5.x下升级python到python2.7版本教程
2015/02/14 Python
Python中的高级函数map/reduce使用实例
2015/04/13 Python
Python使用time模块实现指定时间触发器示例
2017/05/18 Python
对numpy中轴与维度的理解
2018/04/18 Python
python flask实现分页的示例代码
2018/08/02 Python
python实现QQ邮箱/163邮箱的邮件发送
2019/01/22 Python
详解Python sys.argv使用方法
2019/05/10 Python
windows下安装Python虚拟环境virtualenvwrapper-win
2019/06/14 Python
使用Rasterio读取栅格数据的实例讲解
2019/11/26 Python
Python无损压缩图片的示例代码
2020/08/06 Python
使用html2canvas将页面转成图并使用用canvas2image下载
2019/04/04 HTML / CSS
自荐信怎么写好
2013/11/11 职场文书
皮肤科医师岗位职责
2013/12/04 职场文书
超市5.1促销活动
2014/01/15 职场文书
一体化教学实施方案
2014/05/10 职场文书
幼儿园教师师德师风演讲稿:爱我所爱 无悔青春
2014/09/10 职场文书
幼儿园五一劳动节活动总结
2015/02/09 职场文书
卡特教练观后感
2015/06/08 职场文书
浅谈Redis 中的过期删除策略和内存淘汰机制
2022/04/03 Redis