JS实现方形抽奖效果


Posted in Javascript onAugust 27, 2018

本文实例为大家分享了JS实现抽奖效果展示的具体代码,供大家参考,具体内容如下

展示:

JS实现方形抽奖效果JS实现方形抽奖效果

HTML:

<div id="table"></div>
<div id="btn">
   <button onclick="start('p', 'active','newactive', 100)">顺序抽/停止</button>
  <button onclick="startRan('p', 'active','newactive', 100)">随机抽/停止</button>
</div>

CSS:

table {
 text-align: center;
 border-collapse: collapse;
}

table * {
 width: 60px;
 height: 60px;
}

#btn {
 box-sizing: border-box;
 width: 190px;
 display: flex;
 justify-content: space-between;
 align-items: center;
}

#btn * {
 flex-grow: 1;
 background-color: red;
 border: 1px solid #000;
 color: #fff;
 height: 30px;
 font-size: 10px;
}

.active {
 background-color: #ccc;
}

.newactive {
 background-color: #00ffff;
}

JavaScript:

// 定义一个奖池
 var jackpot = [
  ['奖品A1', '奖品A2', '奖品A3'],
  ['奖品B1', '奖品B2', '奖品B3'],
  ['奖品C1', '奖品C2', '奖品C3']
 ];

 /**
  * [table 创建表格]
  * @param {[Array]} arr  [奖品数组]
  * @param {[String]} selector [选择器]
  * @return {[String]} table [返回一个HTML标签]
  */
 function table(arr, selector) {

  var table = '<table border="1">';

  for (var i = 0; i < arr.length; i++) {

   table += '<tr>';

   for (var j = 0; j < arr[i].length; j++) {

    table += '<td class="' + selector + '">' + arr[i][j] + '</td>';

   }

   table += '</tr>';

  }

  table += '</table>';

  return table;

 }

 // 输出奖池
 document.getElementById('table').innerHTML = table(jackpot, 'p');

 var key = true; // start,startRan控制器
 var num = 3; // 抽奖次数
 // 抽过的还能抽  可定义抽奖次数-->次数限制      num需要定义
 //     不定义抽奖次数-->次数无限      num不需定义
 // 抽过的不能抽  可定义抽奖次数-->次数限制(次数不超过选择器长度) num需要定义
 //     不定义抽奖次数-->次数等于选择器长度    num需要定义

 /**
  * [start 开始抽奖]
  * @param {[String]} selector [选择器]
  * @param {[String]} addselector [给选中的添加样式]
  * @param {[String]} newaddselector [中奖奖品样式]
  * @param {[Number]} speed  [时间越小,速度越快]
  * @return {[type]}    [description]
  */
 function start(selector, addselector, newaddselector, speed) {

  if (key) {

   if (typeof(num) == 'undefined' || num != 0) {

    var count = 0;

    // 如果写成var timer会每次执行时重新定义一个timer,那么clearInterval(timer)只能清除后面定义的那个timer,前面定义的已经没有变量指向了 无法清除
    timer = setInterval(function() {

     if (count < $('.' + selector).length) {

      $('.' + selector).eq(count).addClass(addselector);

      $('.' + selector).eq(count).siblings().removeClass(addselector);

      $('.' + selector).eq(count).parent().siblings().children().removeClass(addselector);

      count++;

     } else {

      count = 0;

     }

    }, speed);

    if(typeof(num) != 'undefined'){

     num--;

    }

   } else{

    key = false;

    console.log("抽奖结束");

   }

  } else {

   clearInterval(timer);

   // 决定抽中的奖品的样式和抽中的奖品能否继续抽
   $('.' + addselector).addClass(newaddselector).removeClass(selector);

   // 奖品
   console.log($('.' + addselector).html());

  }

  key = !key;

 }

 /**
  * [start 开始抽奖]
  * @param {[String]} selector [选择器]
  * @param {[String]} addselector [给选中的添加样式]
  * @param {[String]} newaddselector [中奖奖品样式]
  * @param {[Number]} speed  [时间越小,速度越快]
  * @return {[type]}    [description]
  */
 function startRan(selector, addselector, newaddselector, speed) {

  if (key) {

   if (typeof(num) == 'undefined' || num != 0) {

    // 如果写成var timer会每次执行时重新定义一个timer,那么clearInterval(timer)只能清除后面定义的那个timer,前面定义的已经没有变量指向了 无法清除
    timer = setInterval(function() {

     var count = Math.floor(Math.random() * $('.' + selector).length);

     $('.' + selector).eq(count).addClass(addselector);

     $('.' + selector).eq(count).siblings().removeClass(addselector);

     $('.' + selector).eq(count).parent().siblings().children().removeClass(addselector);

    }, speed);

    if(typeof(num) != 'undefined'){

     num--;

    }

   } else {

    key = false;

    console.log("抽奖结束");

   }


  } else {

   clearInterval(timer);

   // 决定抽中的奖品的样式和抽中的奖品能否继续抽
   $('.' + addselector).addClass(newaddselector).removeClass(selector);

   // 奖品
   console.log($('.' + addselector).html());

  }

  key = !key;

}

GitHub:地址

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JSON 学习之完全手册 图文
May 29 Javascript
JS 对象介绍
Jan 20 Javascript
jQuery 选择器(61种)整理总结
Sep 26 Javascript
Vue.js鼠标悬浮更换图片功能
May 17 Javascript
JS写XSS cookie stealer来窃取密码的步骤详解
Nov 20 Javascript
解决JavaScript中0.1+0.2不等于0.3问题
Oct 23 Javascript
vue 中 beforeRouteEnter 死循环的问题
Apr 23 Javascript
如何获取vue单文件自身源码路径
May 06 Javascript
解决Layui数据表格的宽高问题
Sep 28 Javascript
TypeScript之调用栈的实现
Dec 31 Javascript
JQuery获得内容和属性方法解析
May 30 jQuery
vant 解决tab切换插件标题样式自定义的问题
Nov 13 Javascript
对vuejs的v-for遍历、v-bind动态改变值、v-if进行判断的实例讲解
Aug 27 #Javascript
Vuex 在Vue 组件中获得Vuex 状态state的方法
Aug 27 #Javascript
JS实现匀速与减速缓慢运动的动画效果封装示例
Aug 27 #Javascript
vue展示dicom文件医疗系统的实现代码
Aug 27 #Javascript
vue中子组件的methods中获取到props中的值方法
Aug 27 #Javascript
最适应的vue.js的form提交涉及多种插件【推荐】
Aug 27 #Javascript
vue里面v-bind和Props 利用props绑定动态数据的方法
Aug 27 #Javascript
You might like
Ajax PHP简单入门教程代码
2008/04/25 PHP
php 连接mssql数据库 初学php笔记
2010/03/01 PHP
PHP数据类型之整数类型、浮点数的介绍
2013/04/28 PHP
PHP中浮点数计算比较及取整不准确的解决方法
2015/01/09 PHP
使用正则去除php代码中的注释方法
2016/11/03 PHP
javascript 常用代码技巧大收集
2009/02/25 Javascript
JavaScript Title、alt提示(Tips)实现源码解读
2010/12/12 Javascript
jQuery插件开发基础简单介绍
2013/01/07 Javascript
一个级联菜单代码学习及removeClass与addClass的应用
2013/01/24 Javascript
jquery创建表格(自动增加表格)代码分享
2013/12/25 Javascript
jQuery学习笔记之 Ajax操作篇(三) - 过程处理
2014/06/23 Javascript
JS采用绝对定位实现回到顶部效果完整实例
2016/06/20 Javascript
对Js OOP编程 创建对象的一些全面理解
2016/07/26 Javascript
jQuery实现根据生日计算年龄 星座 生肖
2016/11/23 Javascript
关于vue.extend和vue.component的区别浅析
2017/08/16 Javascript
微信小程序自定义组件实现tabs选项卡功能
2018/07/14 Javascript
vue视频播放插件vue-video-player的具体使用方法
2019/11/08 Javascript
vue-cli中实现响应式布局的方法
2021/03/02 Vue.js
跟老齐学Python之不要红头文件(2)
2014/09/28 Python
Python中使用wxPython开发的一个简易笔记本程序实例
2015/02/08 Python
python中reload(module)的用法示例详解
2017/09/15 Python
Python文本特征抽取与向量化算法学习
2017/12/22 Python
python自动化报告的输出用例详解
2018/05/30 Python
python实现音乐下载的统计
2018/06/20 Python
Python连接Mssql基础教程之Python库pymssql
2018/09/16 Python
python分数表示方式和写法
2019/06/26 Python
python opencv把一张图片嵌入(叠加)到另一张图片上的实现代码
2020/06/11 Python
mac安装python3后使用pip和pip3的区别说明
2020/09/01 Python
美国知名平价彩妆品牌:e.l.f. Cosmetics
2017/11/20 全球购物
自荐信如何制作?
2014/02/21 职场文书
群众路线教育实践活动剖析材料
2014/09/30 职场文书
工作态度不好检讨书
2015/05/06 职场文书
初中班主任工作总结2015
2015/05/13 职场文书
唐山大地震观后感
2015/06/05 职场文书
css display table 自适应高度、宽度问题的解决
2021/05/07 HTML / CSS
MySql存储过程之逻辑判断和条件控制
2021/05/26 MySQL