JavaScript 實(shí)現(xiàn)九宮格抽獎(jiǎng)

九格宮抽獎(jiǎng)相信大家都玩過艰匙,今天就用 JavaScript 寫個(gè)九宮格抽獎(jiǎng)玩玩蹭越。讓中獎(jiǎng)不再是夢(mèng)!

1.預(yù)覽效果

image

效果圖為屏幕錄制軟件生成弛槐,以至于出現(xiàn)滾動(dòng)不連貫懊亡。實(shí)際運(yùn)行中不會(huì)出現(xiàn)不連貫的滾動(dòng)效果

2.完整代碼

代碼可直接復(fù)制運(yùn)行查看效果(圖片記得更換)

<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>JavaScript 實(shí)現(xiàn)九宮格抽獎(jiǎng)</title>
<style>
    body{
        background-color: #2c9afc;
    }
    #container {
        width: 330px;
        height: 340px;
        margin: 10% auto;
        border: 7px solid #99d4ff;
        border-radius: 10px;
        padding: 2%;
    }
    #list {
        width: 330px;
        height: 340px;
        list-style: none;
        margin: 0;
        padding: 0;
    }
    #list li,
    #list span {
        width: 100px;
        height: 100px;
        float: left;
        text-align: center;
        line-height: 100px;
        position: relative;
        background-color: #384f9a;
        margin: 1.4%;
        border-radius: 5px;
    }
    #list li img{
        display: block;
        width: 100%;
        height: 100%;
    }
    #list li .mask{
        width: 100%;
        height: 100%;
        position: absolute;
        left:0;
        top:0;
        background: url(images/mask.png) no-repeat;
        background-size: cover;
        display: none;
    }
    #list span:hover {
        cursor: pointer;
        color: orange;
        font-size: 18px;
    }
    #list .active .mask{
        display: block;
    }
    #message {
        line-height: 32px;
        color: #9a9a9a;
        text-align: center;
        position:absolute;
        left: 50%;
        top: 50px;
        width: 300px;
        height: 50px;
        margin-left: -150px;
        display: none;
        background: #000;
        color: #fff;
    }
</style>
</head>
<body>            
    <h3 style="text-align:center;margin-top: 10%;color:white">JavaScript 實(shí)現(xiàn)九宮格抽獎(jiǎng)</h3>
    <div id="container">
        <ul id="list">
            <!-- img標(biāo)簽放獎(jiǎng)品圖片 -->
            <!-- mask類為抽獎(jiǎng)滾動(dòng)起來的標(biāo)記 -->
            <li><img src="images/1.png"/><div class="mask"></div></li>
            <li><img src="images/2.png"/><div class="mask"></div></li>
            <li><img src="images/3.png"/><div class="mask"></div></li>
            <li><img src="images/4.png"/><div class="mask"></div></li>
            <span id="startbutton" onclick="startlottery()" style="background-color:#ff3a59;color:white;font-size: 20px;">開始抽獎(jiǎng)</span>
            <li><img src="images/5.png"/><div class="mask"></div></li>
            <li><img src="images/6.png"/><div class="mask"></div></li>
            <li><img src="images/7.png"/><div class="mask"></div></li>
            <li><img src="images/8.png"/><div class="mask"></div></li>
        </ul>
        <div id="message"></div><!-- 獲獎(jiǎng)信息展示 -->
    </div>
</body>

<script type="text/javascript">

    var container = document.getElementById('container'),
        li = container.getElementsByTagName('li'),
        span = document.getElementById('startbutton'),
        message = document.getElementById('message'),
        timer = null;
        bReady = true;//定義一個(gè)抽獎(jiǎng)開關(guān)

    var prize = [0,1,2,4,7,6,5,3];//獎(jiǎng)品li標(biāo)簽滾動(dòng)的順序

    var num = 0;//num用來存放得到的隨機(jī)函數(shù),也就是抽中的獎(jiǎng)品

    //開始抽獎(jiǎng)
    function startlottery(){
        if(bReady) {//當(dāng)抽獎(jiǎng)開關(guān)為true的時(shí)候乎串,可點(diǎn)擊抽獎(jiǎng)
            message.style.display="none";//將獲獎(jiǎng)信息div隱藏(以防止上次抽獎(jiǎng)信息還顯示)
            span.style.background="#ada7a8";
            bReady = false;//抽獎(jiǎng)開關(guān)設(shè)為false 處于抽獎(jiǎng)中 即不能點(diǎn)擊抽獎(jiǎng)
            num = getrandomnum(1,9)//得到一個(gè)隨機(jī)數(shù)(即獎(jiǎng)品)
            // console.log(num)
            startinit(num);//執(zhí)行抽獎(jiǎng)初始化
        }
    }


    //抽中的獎(jiǎng)品 返回1-9的整數(shù)店枣,包含1,不包含9
    function getrandomnum(n, m) {
        return parseInt((m - n) * Math.random() + n);
    }


    //抽獎(jiǎng)初始化
    function startinit(num) {
        var i = 0;  //定義一個(gè)i 用來計(jì)算抽獎(jiǎng)跑動(dòng)的總次數(shù)
        var t =200;  //抽獎(jiǎng)跑動(dòng)的速度 初始為200毫秒
        var rounds = 5;  //抽獎(jiǎng)轉(zhuǎn)動(dòng)的圈數(shù)
        var rNum = rounds*8;  //標(biāo)記跑動(dòng)的次數(shù)(這是一個(gè)條件判斷分界線)
        timer = setTimeout(startscroll, t);//每t毫秒執(zhí)行startscroll函數(shù)


        //抽獎(jiǎng)滾動(dòng)的函數(shù)
        function startscroll() {

            //每次滾動(dòng)抽獎(jiǎng)將所有l(wèi)i的class都設(shè)為空
            for(var j = 0; j < li.length; j++) {
                li[j].className = '';
            }

            var prizenum = prize[i%li.length];  //通過i余8得到此刻在prize數(shù)組中的數(shù)字叹誉,該數(shù)字就是mask標(biāo)記出現(xiàn)的位置
            li[prizenum].className = "active";
            i++;

            if(i<rNum-8){  //當(dāng)i小于轉(zhuǎn)(rNum-8次)的數(shù)量鸯两,t不變還是200毫秒
                timer = setTimeout(startscroll, t);//繼續(xù)執(zhí)行抽獎(jiǎng)滾動(dòng)
            }else if(i>= rNum-8 && i< rNum+num){
                //t時(shí)間變長(zhǎng),此時(shí)計(jì)時(shí)器運(yùn)行速度降低长豁,同時(shí)標(biāo)簽刷新速度也降低
                t+=(i-rNum+8)*5;
                timer = setTimeout(startscroll, t);//繼續(xù)執(zhí)行抽獎(jiǎng)滾動(dòng)
            }
            if( i >= rNum+num){//當(dāng)i大于轉(zhuǎn)rNum加隨機(jī)數(shù)字num次計(jì)時(shí)器結(jié)束钧唐,出現(xiàn)提示框提示中獎(jiǎng)信息

                if (num==1) {
                   message.innerHTML="恭喜你中了耳機(jī)";
                }else if(num==2){
                   message.innerHTML="恭喜你中了iPad";
                }else if(num==3){
                   message.innerHTML="感謝參與";
                }else if(num==4){
                   message.innerHTML="恭喜你中了洋娃娃";
                }else if(num==5){
                   message.innerHTML="恭喜你中了紅色鞋子";
                }else if(num==6){
                   message.innerHTML="恭喜你中了白色手機(jī)";
                }else if(num==7){
                   message.innerHTML="恭喜你中了黑色手機(jī)";
                }else if(num==8){
                   message.innerHTML="恭喜你中了藍(lán)色鞋子";
                }

                var timer2 = null;
                timer2 = setTimeout(function(){
                    message.style.display="block";//獎(jiǎng)品展示的信息為顯示狀態(tài)
                    span.style.background="#ff3a59";
                    clearTimeout(timer2);
                },1000);
                bReady = true;//當(dāng)計(jì)時(shí)器結(jié)束后讓span標(biāo)簽變?yōu)槌楠?jiǎng)狀態(tài)
                clearTimeout(timer);
            }

        }
    }

</script>
</html>

3.代碼分析

1. prize

    var prize = [0,1,2,4,7,6,5,3];//獎(jiǎng)品li標(biāo)簽滾動(dòng)的順序

數(shù)組prize中的數(shù)字就是li標(biāo)簽對(duì)應(yīng)的索引值,由于是九宮格抽獎(jiǎng)匠襟,因此抽獎(jiǎng)滾動(dòng)的順序并不是按li標(biāo)簽的索引順序钝侠,以下是li標(biāo)簽實(shí)際滾動(dòng)的順序圖分析:

image

2. getrandomnum(1,9)

    //抽中的獎(jiǎng)品 返回1-9的整數(shù),包含1宅此,不包含9
    function getrandomnum(n, m) {
        return parseInt((m - n) * Math.random() + n);
    }

因?yàn)橹挥?個(gè)獎(jiǎng)品,所以得到的隨機(jī)整數(shù)不包含9

3. 變量 i爬范、rounds父腕、rNum

    var i = 0;  //定義一個(gè)i 用來計(jì)算抽獎(jiǎng)跑動(dòng)的總次數(shù)
    var rounds = 5;  //抽獎(jiǎng)轉(zhuǎn)動(dòng)的圈數(shù)
    var rNum = rounds*8;  //標(biāo)記跑動(dòng)的次數(shù)(這是一個(gè)條件判斷分界線)

i 是用來計(jì)算li標(biāo)簽滾動(dòng)的次數(shù),滾動(dòng)一次加1青瀑;

rounds 及 rNum 用來讓滾動(dòng)抽獎(jiǎng)變慢及停止的判斷條件璧亮;

4. prizenum

    var prizenum = prize[i%li.length];  //通過i余8得到此刻在prize數(shù)組中的數(shù)字,該數(shù)字就是mask標(biāo)記出現(xiàn)的位置
    li[prizenum].className = "active";

i%li.length 為i除以li標(biāo)簽長(zhǎng)度得到的余數(shù)(始終為0-7范圍的整數(shù))斥难,放進(jìn)prize數(shù)組中枝嘶,得到的prizenum數(shù)字就是當(dāng)前滾動(dòng)到的li標(biāo)簽索引值

聲明:文章已取得微信公眾號(hào) GitWeb 授權(quán),轉(zhuǎn)載需標(biāo)明文章來源出處

image
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末哑诊,一起剝皮案震驚了整個(gè)濱河市群扶,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖竞阐,帶你破解...
    沈念sama閱讀 207,248評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件缴饭,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡骆莹,警方通過查閱死者的電腦和手機(jī)颗搂,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,681評(píng)論 2 381
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來幕垦,“玉大人丢氢,你說我怎么就攤上這事∠雀模” “怎么了疚察?”我有些...
    開封第一講書人閱讀 153,443評(píng)論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)盏道。 經(jīng)常有香客問我稍浆,道長(zhǎng),這世上最難降的妖魔是什么猜嘱? 我笑而不...
    開封第一講書人閱讀 55,475評(píng)論 1 279
  • 正文 為了忘掉前任衅枫,我火速辦了婚禮,結(jié)果婚禮上朗伶,老公的妹妹穿的比我還像新娘弦撩。我一直安慰自己,他們只是感情好论皆,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,458評(píng)論 5 374
  • 文/花漫 我一把揭開白布益楼。 她就那樣靜靜地躺著,像睡著了一般点晴。 火紅的嫁衣襯著肌膚如雪感凤。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,185評(píng)論 1 284
  • 那天粒督,我揣著相機(jī)與錄音陪竿,去河邊找鬼。 笑死屠橄,一個(gè)胖子當(dāng)著我的面吹牛族跛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播锐墙,決...
    沈念sama閱讀 38,451評(píng)論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼礁哄,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了溪北?” 一聲冷哼從身側(cè)響起桐绒,我...
    開封第一講書人閱讀 37,112評(píng)論 0 261
  • 序言:老撾萬榮一對(duì)情侶失蹤夺脾,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后掏膏,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體劳翰,經(jīng)...
    沈念sama閱讀 43,609評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,083評(píng)論 2 325
  • 正文 我和宋清朗相戀三年馒疹,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了佳簸。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,163評(píng)論 1 334
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡颖变,死狀恐怖生均,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情腥刹,我是刑警寧澤马胧,帶...
    沈念sama閱讀 33,803評(píng)論 4 323
  • 正文 年R本政府宣布,位于F島的核電站衔峰,受9級(jí)特大地震影響佩脊,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜垫卤,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,357評(píng)論 3 307
  • 文/蒙蒙 一威彰、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧穴肘,春花似錦歇盼、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,357評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至慨代,卻和暖如春邢笙,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背侍匙。 一陣腳步聲響...
    開封第一講書人閱讀 31,590評(píng)論 1 261
  • 我被黑心中介騙來泰國(guó)打工氮惯, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人丈积。 一個(gè)月前我還...
    沈念sama閱讀 45,636評(píng)論 2 355
  • 正文 我出身青樓筐骇,卻偏偏與公主長(zhǎng)得像债鸡,于是被迫代替她去往敵國(guó)和親江滨。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,925評(píng)論 2 344