首頁 >web前端 >js教程 >javascript實現數組中的內容隨機輸出_javascript技巧

javascript實現數組中的內容隨機輸出_javascript技巧

WBOY
WBOY原創
2016-05-16 15:45:543195瀏覽

有時候我們可能需要從陣列中隨機抽出一項內容,以下就透過一段程式碼實例介紹一下如何實現此效果。

程式碼如下:

<script type="text/JavaScript"> 
var theArray=new Array();
theArray[0]="脚本之家";
theArray[1]="脚本之家一";
theArray[2]="脚本之家二";
theArray[3]="脚本之家三";
theArray[4]="脚本之家四";
theArray[5]="脚本之家五";
theArray[6]="脚本之家六";
function ranFun()
{
 return parseInt(Math.random()*7);
}
document.write(theArray[ranFun()]);
</script>

以上程式碼可以隨機輸出數組中的元素,程式碼非常的簡單,透過使用隨機數函數為數組提供一個隨機的索引即可。

從陣列隨機讀取N條不同資料

方法一

var ary = new Array();
var xiaowu=new Array(
“1我的
“,
“2我的
“,
“3我的
“,
“4我的
“,
“5我的
“,
“6我的
“,
“7我的
“,
“8我的
“,
“9我的
“,
“10我的
“,
“11我的
“,
“12我的
“,
“13我的
“,
“14我的
“,
“15我的
“,
“16我的
“,
“17我的
“,
“18我的
“,
“19我的
“,
“20我的
”
);
var s01=xiaowu.length
while(ary.length < 6)
{
var tmp =xiaowu[parseInt(Math.random()*s01)]
var b = false;
for (var i=0; i<ary.length; i++)
{
if (ary[i] == tmp)
{
b = true;
break;
}
}
if (!b)
ary[ary.length] = tmp;
}
document.write(ary[0]);
document.write(ary[1]);
document.write(ary[2]);
document.write(ary[3]);
document.write(ary[4]);
document.write(ary[5]);

方法二

//从一个给定的数组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 ArrList=[1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22,23,24,25,26,27,28,29,30,31,32,33];
alert(getArrayItems(ArrList,6));

這段JS程式碼可以對陣列內的元素進行隨機排列,這個非常有用,例如我們在玩撲克牌的時候可以讓撲克牌進行排列,也就是電腦洗牌。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn