[原创]js获取数组任意个不重复的随机数组元素


Posted in Javascript onMarch 15, 2010
<script language="javascript"> 
//从一个给定的数组arr中,随机返回num个不重复项 
function getArrayItems(arr, num) { 
//新建一个数组,将传入的数组复制过来,用于运算,而不要直接操作传入的数组; 
var temp_array = new Array(); 
for (var index in arr) { 
temp_array.push(arr[index]); 
} 
//取出的数值项,保存在此数组 
var return_array = new Array(); 
for (var i = 0; i<num; i++) { 
//判断如果数组还有可以取出的元素,以防下标越界 
if (temp_array.length>0) { 
//在数组中产生一个随机索引 
var arrIndex = Math.floor(Math.random()*temp_array.length); 
//将此随机索引的对应的数组元素值复制出来 
return_array[i] = temp_array[arrIndex]; 
//然后删掉此索引的数组元素,这时候temp_array变为新的数组 
temp_array.splice(arrIndex, 1); 
} else { 
//数组中数据项取完后,退出循环,比如数组本来只有10项,但要求取出20项. 
break; 
} 
} 
return return_array; 
} 
//测试 
var my_array = new Array(); 
for (i = 0; i < 20; i++) 
{ 
my_array[i] = "Num:"+i; 
} 
my_array = getArrayItems(my_array,5); 
for (i = 0; i < my_array.length; i++) 
{ 
alert(my_array[i]); 
} 
</script>
Javascript 相关文章推荐
模仿百度三维地图的js数据分享
May 12 Javascript
使用javascript实现ListBox左右全选,单选,多选,全请
Nov 07 Javascript
当鼠标移动时出现特效的JQuery代码
Nov 08 Javascript
JQuery中使文本框获得焦点的方法实例分析
Feb 28 Javascript
js实现华丽的九九乘法表效果
Mar 29 Javascript
微信小程序开发之从相册获取图片 使用相机拍照 本地图片上传
Apr 18 Javascript
微信小程序组件之srcoll-view的详解
Oct 19 Javascript
vue+webpack实现异步加载三种用法示例详解
Apr 24 Javascript
jQuery动态移除与增加onclick属性的方法详解
Jun 07 jQuery
angularJs中ng-model-options设置数据同步的方法
Sep 30 Javascript
swiper4实现移动端导航栏tab滑动切换
Oct 16 Javascript
Vue实现购物小球抛物线的方法实例
Nov 22 Vue.js
javascript实现的在当前窗口中漂浮框的代码
Mar 15 #Javascript
javascript 用记忆函数快速计算递归函数
Mar 15 #Javascript
JS 密码强度验证(兼容IE,火狐,谷歌)
Mar 15 #Javascript
javascript css styleFloat和cssFloat
Mar 15 #Javascript
javascript 嵌套的函数(作用域链)
Mar 15 #Javascript
JavaScript 嵌套函数指向this对象错误的解决方法
Mar 15 #Javascript
JQuery 常用操作代码
Mar 14 #Javascript
You might like
PHP的关于变量和日期处理的一些面试题目整理
2015/08/10 PHP
laravel 中如何使用ajax和vue总结
2017/08/16 PHP
laravel validate 设置为中文的例子(验证提示为中文)
2019/09/29 PHP
javascript FormatNumber函数实现方法
2008/12/30 Javascript
关于jQuery新的事件绑定机制on()的使用技巧
2013/04/26 Javascript
jquery 清空file域示例(兼容个浏览器)
2013/10/11 Javascript
js出生日期 年月日级联菜单示例代码
2014/01/10 Javascript
Nodejs中调用系统命令、Shell脚本和Python脚本的方法和实例
2015/01/01 NodeJs
javascript中动态函数用法实例分析
2015/05/14 Javascript
Javascript实现可旋转的圆圈实例代码
2015/08/04 Javascript
Jquery easyui开启行编辑模式增删改操作
2016/01/14 Javascript
arcgis for js 修改infowindow样式的方法
2016/11/02 Javascript
详解Nodejs基于mongoose模块的增删改查的操作
2016/12/21 NodeJs
JavaScript 总结几个提高性能知识点(推荐)
2017/02/20 Javascript
ionic2懒加载配置详解
2017/09/01 Javascript
纯js代码生成可搜索选择下拉列表的实例
2018/01/11 Javascript
使用sessionStorage解决vuex在页面刷新后数据被清除的问题
2018/04/13 Javascript
微信小程序中使用wxss加载图片并实现动画效果
2018/08/13 Javascript
Koa 中的错误处理解析
2019/04/09 Javascript
百度小程序自定义通用toast组件
2019/07/17 Javascript
vue.js实现二级菜单效果
2019/10/19 Javascript
js实现列表按字母排序
2020/08/11 Javascript
vue pages 多入口项目 + chainWebpack 全局引用缩写说明
2020/09/21 Javascript
[32:26]EG vs IG 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
django小技巧之html模板中调用对象属性或对象的方法
2018/11/30 Python
Python之修改图片像素值的方法
2019/07/03 Python
django的auth认证,authenticate和装饰器功能详解
2019/07/25 Python
PyCharm中关于安装第三方包的三个建议
2020/09/17 Python
Python3中小括号()、中括号[]、花括号{}的区别详解
2020/11/15 Python
css3 利用transform打造走动的2D时钟
2020/10/20 HTML / CSS
BOSE德国官网:尽探索之力,享音乐之极
2016/12/11 全球购物
仓库文员岗位职责
2014/04/06 职场文书
消防安全标语
2014/06/07 职场文书
科长个人四风问题整改措施思想汇报
2014/10/13 职场文书
详解Redis集群搭建的三种方式
2021/05/31 Redis
golang fmt格式“占位符”的实例用法详解
2021/07/04 Golang