咱们平时在看一些选秀节目或一些歌唱类比赛节目时常常会看到在现场的大屏幕上会有观众的手机号在滚动来选出谁是幸运观众或谁中了什么奖项,这些手机号都是现场观众或场外观众在给选手投票时产生的,当主持人一声开始令下,大屏幕上的手机号就会快速随机滚动,当主持人一声停令下,大屏幕上会随机出现几个中止滚动的手机号,这种手机号批量随机滚动的效果,就是咱们今天要实现的效果。注意,在这个效果的实现当中最核心的就是随机和不重复。javascript
下面,我就简单来介绍一下原理:
一、随机,咱们要写一个随机数,并且这个随机数不能重复,这个不能重复的随机数说白了就是咱们从数据库中取出的手机号的索引;
二、使用定时器不断的产生不重复的随机数,用这些不重复的随机数去绑定手机号并将手机号追加在一个盒子中;
三、去除中奖的手机号(这个前端貌似无法实现,只能后台去控制),当开始抽奖时再次产生不重复的随机数,再次用这些随机数去绑定手机号,直到抽奖结束。css
正好咱们公司最近年会上有这样的现场抽奖,因而我就作了一个这样的抽奖效果(咱们的抽奖号码是用的咱们每一个人的邀请码,不是手机号,其实原理都同样。),并且能够控制每次中奖的人数,配上后台代码和数据库后效果还不错,接下来就把实现代码分享出来吧。html
<!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