js手機(jī)號(hào)批量滾動(dòng)抽獎(jiǎng)實(shí)現(xiàn)代碼
我們平時(shí)在看一些選秀節(jié)目或一些歌唱類(lèi)比賽節(jié)目時(shí)經(jīng)常會(huì)看到在現(xiàn)場(chǎng)的大屏幕上會(huì)有觀眾的手機(jī)號(hào)在滾動(dòng)來(lái)選出誰(shuí)是幸運(yùn)觀眾或誰(shuí)中了什么獎(jiǎng)項(xiàng),這些手機(jī)號(hào)都是現(xiàn)場(chǎng)觀眾或場(chǎng)外觀眾在給選手投票時(shí)產(chǎn)生的,當(dāng)主持人一聲開(kāi)始令下,大屏幕上的手機(jī)號(hào)就會(huì)快速隨機(jī)滾動(dòng),當(dāng)主持人一聲停令下,大屏幕上會(huì)隨機(jī)出現(xiàn)幾個(gè)停止?jié)L動(dòng)的手機(jī)號(hào),這種手機(jī)號(hào)批量隨機(jī)滾動(dòng)的效果,就是我們今天要實(shí)現(xiàn)的效果。注意,在這個(gè)效果的實(shí)現(xiàn)當(dāng)中最核心的就是隨機(jī)和不重復(fù)。
下面,我就簡(jiǎn)單來(lái)介紹一下原理:
1、隨機(jī),我們要寫(xiě)一個(gè)隨機(jī)數(shù),而且這個(gè)隨機(jī)數(shù)不能重復(fù),這個(gè)不能重復(fù)的隨機(jī)數(shù)說(shuō)白了就是我們從數(shù)據(jù)庫(kù)中取出的手機(jī)號(hào)的索引;
2、使用定時(shí)器不斷的產(chǎn)生不重復(fù)的隨機(jī)數(shù),用這些不重復(fù)的隨機(jī)數(shù)去綁定手機(jī)號(hào)并將手機(jī)號(hào)追加在一個(gè)盒子中;
3、去除中獎(jiǎng)的手機(jī)號(hào)(這個(gè)前端貌似沒(méi)法實(shí)現(xiàn),只能后臺(tái)去控制),當(dāng)開(kāi)始抽獎(jiǎng)時(shí)再次產(chǎn)生不重復(fù)的隨機(jī)數(shù),再次用這些隨機(jī)數(shù)去綁定手機(jī)號(hào),直到抽獎(jiǎng)結(jié)束。
正好我們公司最近年會(huì)上有這樣的現(xiàn)場(chǎng)抽獎(jiǎng),于是我就做了一個(gè)這樣的抽獎(jiǎng)效果(我們的抽獎(jiǎng)號(hào)碼是用的我們每個(gè)人的邀請(qǐng)碼,不是手機(jī)號(hào),其實(shí)原理都一樣。),而且可以控制每次中獎(jiǎng)的人數(shù),配上后臺(tái)代碼和數(shù)據(jù)庫(kù)后效果還不錯(cuò),接下來(lái)就把實(shí)現(xiàn)代碼
分享出來(lái)吧。
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="utf-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="renderer" content="webkit"> <title>互融CLUB</title> <script type="text/javascript" src="js/jquery.min.js"></script> <style> *{margin:0;padding:0;} img{display:block;} i{font-style:normal;} .vetically{justify-content:center;align-items:center;display:-webkit-flex;} .prize_con{position: absolute;width: 100%;height: 100%;background: url(images/firstp_bg.jpg) no-repeat left top / 100% 100%;overflow: hidden;} .prize_grade{font-size:98px;color: #ffe9af;text-align: center;margin: 160px auto 0;} .prize_list{width:55%;height:350px;margin: 20px auto 55px;text-align: center;overflow: hidden;} .prize_list ul{width:100%;font-size:0;} .prize_list li{display:inline-block;font-size:45px;color:#f1bf90;text-align: center;width:20%;line-height:100px;font-family:Arial;} .start{width: 250px;height: 90px;margin:0 auto;cursor:pointer;} .prize_set{position: absolute;right: 60px;bottom: 40px;font-size: 16px;color: #f7f3e8;line-height: 30px;} .prize_set li{display: inline-block;margin-left: 20px;} .set_grade select,.set_people input, .set_money input{background: #fff;width:110px;height:36px;border:1px solid #8f0000;margin-left: .1rem;color: #000;padding-left:10px;} </style> </head> <body> <div class="wrap"> <div class="prize_con"> <p class="prize_grade"><span>開(kāi)始抽獎(jiǎng)</span> <i>0</i>元</p> <div class="prize_list vetically"> <ul> <li>000000</li> <li>000000</li> <li>000000</li> <li>000000</li> <li>000000</li> <li>000000</li> <li>000000</li> <li>000000</li> <li>000000</li> <li>000000</li> </ul> </div> <p class="start"><img src="images/prize_start.png" alt=""></p> <ul class="prize_set"> <li class="set_grade">獎(jiǎng)等 <select id="set_grade"> <option>選擇獎(jiǎng)等</option> <option>特等獎(jiǎng)</option> <option>一等獎(jiǎng)</option> <option>二等獎(jiǎng)</option> <option>三等獎(jiǎng)</option> </select> </li> <li class="set_people">人數(shù)<input type="tel" placeholder="輸入中獎(jiǎng)人數(shù)" id="prizeCount"></li> <li class="set_money">金額<input type="tel" placeholder="輸入中獎(jiǎng)金額" id="prizeMoney"></li> </ul> </div> </div> <input type="hidden" value="0" id="prize_btn"> <script> var ran = 0; var myNumber; var arr = []; var code = [302610,210022,159862,158602,145635,856997,586223,546221,145213,987451,251364,854136,581698,123785,521387,752169,718954,412321,898989,121245,788565,458558,589659,455212,964632,458412,223344,112233,335566,778899]; /*隨機(jī)所有的code并且不重復(fù)*/ function showRandomNum(num) { var li = ""; for(var i = 0; i < code.length; i++){ arr[i] = i; } arr.sort(function(){ return 0.5 - Math.random(); }); for(var i = 0; i < num; i++){ var index = arr[i]; li += '<li>'+code[index]+'</li>'; } $(".prize_list ul").html(li); } $(function () { $(".start").click(function(){ if($("#prize_btn").val() == 0){ if($("#set_grade").val() == "選擇獎(jiǎng)等") { alert("請(qǐng)選擇獎(jiǎng)等"); return; }else if($("#prizeCount").val() == "") { alert("請(qǐng)輸入中獎(jiǎng)人數(shù)"); return; }else if($("#prizeCount").val() > 10) { alert("單次抽獎(jiǎng)人數(shù)不能超過(guò)10人"); return; }else if($("#prizeMoney").val() == "") { alert("請(qǐng)輸入中獎(jiǎng)金額"); return; }else{ $("#prize_btn").val(1); var num = $("#prizeCount").val(); $(this).find("img").attr("src","images/prize_stop.png"); myNumber = setInterval(function(){ showRandomNum(num); }, 30); } }else{ $("#prize_btn").val(0); clearInterval(myNumber); $(this).find("img").attr("src","images/prize_start.png"); } }); //回車(chē)鍵控制開(kāi)始和停止 $(document).keydown(function (event) { var e = event || window.event || arguments.callee.caller.arguments[0]; if (e && e.keyCode == 13) { // enter 鍵 $(".start").click(); } }); $("#set_grade").change(function(){ $(".prize_grade span").text($(this).val()); }); $("#prizeMoney").keyup(function(){ $(".prize_grade i").text($(this).val()); }); }); </script> </body> </html>
效果圖如下:
以下附上源代碼:js手機(jī)號(hào)批量滾動(dòng)抽獎(jiǎng)代碼實(shí)現(xiàn)
想要學(xué)習(xí)更多關(guān)于抽獎(jiǎng)功能的實(shí)現(xiàn),請(qǐng)參考此專(zhuān)題:抽獎(jiǎng)功能
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- js和html5實(shí)現(xiàn)手機(jī)端刮刮卡抽獎(jiǎng)效果完美兼容android/IOS
- js輪盤(pán)抽獎(jiǎng)實(shí)例分析
- js抽獎(jiǎng)實(shí)現(xiàn)隨機(jī)抽獎(jiǎng)代碼效果
- jquery.rotate.js實(shí)現(xiàn)可選抽獎(jiǎng)次數(shù)和中獎(jiǎng)內(nèi)容的轉(zhuǎn)盤(pán)抽獎(jiǎng)代碼
- js實(shí)現(xiàn)簡(jiǎn)單隨機(jī)抽獎(jiǎng)的方法
- js簡(jiǎn)單抽獎(jiǎng)代碼
- js實(shí)現(xiàn)大轉(zhuǎn)盤(pán)抽獎(jiǎng)游戲?qū)嵗?/a>
- 原生JS實(shí)現(xiàn)九宮格抽獎(jiǎng)效果
- javascript 隨機(jī)抽獎(jiǎng)程序代碼
- JS模擬抽獎(jiǎng)序效果實(shí)現(xiàn)代碼
- js實(shí)現(xiàn)抽獎(jiǎng)功能
相關(guān)文章
layui table 復(fù)選框跳頁(yè)后再回來(lái)保持原來(lái)選中的狀態(tài)示例
今天小編就為大家分享一篇layui table 復(fù)選框跳頁(yè)后再回來(lái)保持原來(lái)選中的狀態(tài)示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-10-10JS實(shí)現(xiàn)復(fù)制內(nèi)容到剪貼板功能
本文主要介紹了JS實(shí)現(xiàn)復(fù)制內(nèi)容到剪貼板功能的步驟方法,可兼容所有PC瀏覽器,不兼容手機(jī)端。具有一定的參考價(jià)值,下面跟著小編一起來(lái)看下吧2017-02-02詳解JavaScript中?.、??和??=的用法及使用場(chǎng)景
這篇文章主要為大家詳細(xì)介紹了JavaScript中?.、??和??=的用法及使用場(chǎng)景,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2023-08-08JS實(shí)現(xiàn)中國(guó)公民身份證號(hào)碼有效性驗(yàn)證
這篇文章主要介紹了JS實(shí)現(xiàn)中國(guó)公民身份證號(hào)碼有效性驗(yàn)證,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-02-02JS實(shí)現(xiàn)slide文字框縮放伸展效果代碼
這篇文章主要介紹了JS實(shí)現(xiàn)slide文字框縮放伸展效果代碼,涉及JavaScript響應(yīng)鼠標(biāo)事件動(dòng)態(tài)操作頁(yè)面元素屬性的相關(guān)技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-11-11html的DOM中document對(duì)象anchors集合用法實(shí)例
這篇文章主要介紹了html的DOM中document對(duì)象anchors集合用法,實(shí)例分析了anchors集合的功能及使用技巧,需要的朋友可以參考下2015-01-01JavaScript中常見(jiàn)加密解密方法總結(jié)
這篇文章主要為大家詳細(xì)介紹了JavaScript中常見(jiàn)加密解密方法的實(shí)現(xiàn),文中的示例代碼講解詳細(xì),具有一定的學(xué)習(xí)價(jià)值,感興趣的小伙伴可以了解一下2023-03-03jQuery實(shí)現(xiàn)騰訊信用界面(自制刻度尺)樣式
這篇文章主要介紹了jQuery實(shí)現(xiàn)騰訊信用界面(自制刻度尺)樣式,下文還總結(jié)了關(guān)于jquery中extend的方法,需要的朋友可以參考下2017-08-08JavaScript隊(duì)列函數(shù)和異步執(zhí)行詳解
這篇文章主要為大家詳細(xì)介紹了JavaScript隊(duì)列函數(shù)和異步執(zhí)行的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-06-06