JavaScript实现随机点名器实例详解


Posted in Javascript onMay 07, 2019

你是公司的程序员,年会的时候公司要给员工抽奖发福利,要求你写一个页面小程序,用来随机选出幸运员工,分设一二三等奖大致如下图示例:

JavaScript实现随机点名器实例详解

 JavaScript实现随机点名器实例详解

以下是点名器的一种思路,页面比较简陋,只给出了满足最基本要求的代码户要用到计时器,随机数函数等
本抽奖一二三等奖都只设一名幸运员工,开始结束功能用一个按钮实现

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>点名器</title>
  <style>
    .title{
      font-size:50px;
      font-family: 800;
      color:red;
      margin:50px 430px;
    }
    #Uname{
      width: 300px;
      height: 200px;
      border:3px solid green;
      margin-left:300px;
      margin-top: 0px;
      font-size:50px;
      font-weight: 800;
      text-align: center;
      line-height: 200px;
      float:left;
    }
    .result{
      width: 300px;
      height: 200px;
      font-size: 16px;
      border:3px solid red;
      color:orange;
      margin-left: 100px;
      float:left;
    }

    .result p{
      color:blue;
      font-size: 12px;
    }
    .btn{
      width: 60px;
      height: 200px;
      margin:0 auto;
      margin-top: 20px;

    }
    .btn button{
      width: 50px;

    }
    #prize_3,#prize_2,#prize_1{
      color:red;
      font-size: 16px;
    }
  </style>
</head>
<body>
  <div class="title">XX公司年会抽奖活动</div>
  <div id="Uname" >祝君好运    
  </div>
  <div class="result">
    <p>三等奖:</p>
    <div id="prize_3"></div>
    <p>二等奖:</p>
    <div id="prize_2"></div>
    <p>一等奖:</p>
    <div id="prize_1"></div>
  </div>
  <div class="btn">
    <button onclick="demo()" id="bt">开始</button>
      <!-- <button onclick="stop()">结束</button> -->
  </div>
  <script>
    //获取显示框的内容
    var Uname=document.getElementById('Uname');
    //要随机的员工名单
    var arr=['刘备','曹操','孙权','赵云','大乔','小乔','周瑜','尚香'];
    //获取按钮信息
    var btn=document.getElementById('bt');
    //定义变量存放计时器
    var clock=0;
    //定义变量存放索引值
    var inde=null;
    var prize_3=document.getElementById('prize_3');
    var prize_2=document.getElementById('prize_2');
    var prize_1=document.getElementById('prize_1');

    // 定义是否开启计时器的标志,如果为真开始执行 如果为假则停止
    var st=true;
    // 存放幸运员工名单
    prizes=[];
    function demo(){
      if(st){
        start();
        btn.innerHTML="结束";
        st=false;

      }else{
        stop();
        btn.innerHTML="开始";
        st=true;

      }
    }

    // 开始函数
    function start(){
      clock=setInterval(function(){
        var inde=rand(0,arr.length-1);
        Uname.innerHTML=arr[inde];     
      },50);//设置每50毫秒实行一次
    }
    // 结束点名
    function stop(){
      //从列表最后添加元素
      prizes.push(Uname.innerHTML);
      //关闭定时器
      clearInterval(clock);
      //获取员工名字对应的索引值
      arr.splice(arr.indexOf(Uname.innerHTML),1);
      //当抽奖次数达到三次时,在屏幕上显示幸运员工名单
      if(prizes.length>=3){
        prize_3.innerHTML=prizes[0];
        prize_2.innerHTML=prizes[1];
        prize_1.innerHTML=prizes[2];
      }
    }
    // 封装获取随机数 函数
    function rand(m,n){
      return Math.floor(Math.random()*(n-m+1)+m);
    }
  </script>
</body>
</html>

以上所述是小编给大家介绍的JavaScript随机点名器详解整合,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JavaScript静态的动态
Sep 18 Javascript
JavaScript 学习点滴记录
Apr 24 Javascript
JS高级调试技巧:捕获和分析 JavaScript Error详解
Mar 16 Javascript
jQuery定义背景动态切换效果的方法
Mar 23 Javascript
JavaScript编程中的Promise使用大全
Jul 28 Javascript
浅谈JS之tagNaem和nodeName
Sep 13 Javascript
jQuery鼠标事件总结
Oct 13 Javascript
利用React-router+Webpack快速构建react程序
Oct 27 Javascript
基于jQuery封装的分页组件
Jun 26 jQuery
JS实现百度网盘任意文件强制下载功能
Aug 31 Javascript
通过实例解析JavaScript for in及for of区别
Jun 15 Javascript
5种方法告诉你如何使JavaScript 代码库更干净
Sep 15 Javascript
vue父组件触发事件改变子组件的值的方法实例详解
May 07 #Javascript
微信小程序:数据存储、传值、取值详解
May 07 #Javascript
微信小程序实现用table显示数据库反馈的多条数据功能示例
May 07 #Javascript
详解Vue前端生产环境发布配置实战篇
May 07 #Javascript
7个好用的JavaScript技巧分享(译)
May 07 #Javascript
微信小程序实现获取用户信息并存入数据库操作示例
May 07 #Javascript
vue搜索和vue模糊搜索代码实例
May 07 #Javascript
You might like
php sprintf()函数让你的sql操作更安全
2008/07/23 PHP
PHP 获取远程网页内容的代码(fopen,curl已测)
2011/06/06 PHP
PHP IF ELSE简化/三元一次式的使用
2011/08/22 PHP
php实现字符串首字母大写和单词首字母大写的方法
2015/03/14 PHP
4种PHP异步执行的常用方式
2015/12/24 PHP
PHP如何通过带尾指针的链表实现'队列'
2020/10/22 PHP
精解window.setTimeout()&amp;window.setInterval()使用方式与参数传递问题!
2007/11/23 Javascript
最新的10款jQuery内容滑块插件分享
2011/09/18 Javascript
浅谈jQuery中的eq()与DOM中element.[]的区别
2016/10/28 Javascript
JavaScript中 this 指向问题深度解析
2017/02/21 Javascript
简单实现AngularJS轮播图效果
2020/04/10 Javascript
React教程之Props验证的具体用法(Props Validation)
2017/09/04 Javascript
JS计算两个时间相差分钟数的方法示例
2018/01/10 Javascript
vue.js分页中单击页码更换页面内容的方法(配合spring springmvc)
2018/02/10 Javascript
用vue写一个仿简书的轮播图的示例代码
2018/03/13 Javascript
实例讲解JavaScript预编译流程
2019/01/24 Javascript
如何基于layui的laytpl实现数据绑定的示例代码
2020/04/10 Javascript
JS script脚本中async和defer区别详解
2020/06/24 Javascript
JS hasOwnProperty()方法检测一个属性是否是对象的自有属性的方法
2021/01/29 Javascript
讲解Python中的递归函数
2015/04/27 Python
K-means聚类算法介绍与利用python实现的代码示例
2017/11/13 Python
Python实现爬取百度贴吧帖子所有楼层图片的爬虫示例
2018/04/26 Python
Python面向对象之类和对象实例详解
2018/12/10 Python
解决Django中调用keras的模型出现的问题
2019/08/07 Python
python3 实现爬取TOP500的音乐信息并存储到mongoDB数据库中
2019/08/24 Python
Python单例模式的四种创建方式实例解析
2020/03/04 Python
丹麦优惠购物网站:PLUSSHOP
2019/03/24 全球购物
Weblogic的布署方式
2013/08/23 面试题
输入N,打印N*N矩阵
2012/02/20 面试题
写出二分查找算法的两种实现
2013/05/13 面试题
《月球之谜》教学反思
2014/04/10 职场文书
学校领导班子四风问题整改意见
2014/10/02 职场文书
行政执法队伍作风整顿个人剖析材料
2014/10/11 职场文书
美国旅游签证工作证明
2014/10/14 职场文书
2015年手术室工作总结
2015/05/11 职场文书
2016师德师风学习心得体会
2016/01/12 职场文书