欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

javascript實現(xiàn)抽獎程序的簡單實例

 更新時間:2016年06月07日 15:47:44   投稿:jingxian  
下面小編就為大家?guī)硪黄猨avascript實現(xiàn)抽獎程序的簡單實例。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

昨天開年會的時候看到一個段子說唯品會年會抽獎,結(jié)果大獎都被寫抽獎程序的部門得了,CTO現(xiàn)場review代碼。

簡單想了一下抽獎程序的實現(xiàn),花了十幾分鐘寫了一下,主要用到的知識有數(shù)組添加刪除,以及ES5 數(shù)組新增的indexOf,filter方法,

為了刷新頁面后仍能保存已中獎記錄,用了localStorage存盤。

剛開始是用隨機數(shù)直接取編號,發(fā)現(xiàn)要剔除已中獎的人很麻煩,如果重復(fù)要遞歸調(diào)用,如果中獎的人太多到最后隨機數(shù)取到已中獎的人概率太大,所以換用兩個數(shù)組實現(xiàn),一個記錄已中獎的號碼,一個記錄未中獎的號碼,已中獎的從另一個數(shù)組剔除就行,就不存在遞歸調(diào)用的情況。

具體實現(xiàn)如下:

var start=1,end=20,luckyList=[],futureList=[];//luckyList表示已獲獎的人,futureList表示尚未抽中的人,start,end表示獎券起止編號

//先初始化一下所有人員編號的數(shù)組
for(var i=start;i<=end;i++){
futureList.push(i);
}
//如果刷新了頁面,從localStoreage中恢復(fù)
if(localStorage.getItem("lucky")){
luckyList=localStorage.getItem("lucky").split(",");
futureList=futureList.filter(function(item){
return luckyList.indexOf(item)==-1;
})
console.log(futureList)
}

//抽獎函數(shù),每運行一次,產(chǎn)生一個幸運號碼
function raffle(){
var num= Math.random()*futureList.length;
num=Math.floor(num);
var idx=futureList.indexOf(num);
var result= futureList.splice(idx,1)[0].toString();
luckyList.push(result);
localStorage.setItem("lucky",luckyList);
console.log("抽獎結(jié)果:",result); 

} 
//清除localstorge,如果要復(fù)位程序執(zhí)行此函數(shù)
function clear(){
localStorage.setItem("lucky","");

}

raffle();

以上這篇javascript實現(xiàn)抽獎程序的簡單實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評論