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传递变量: 值传递?引用传递?
Feb 22 Javascript
jQuery学习之prop和attr的区别示例介绍
Nov 15 Javascript
JS+DIV实现鼠标划过切换层效果的实例代码
Nov 26 Javascript
JS实现让访问者自助选择网页文字颜色的方法
Feb 24 Javascript
JavaScript中日期的相关操作方法总结
Oct 24 Javascript
vue 中自定义指令改变data中的值
Jun 02 Javascript
vue实现表格增删改查效果的实例代码
Jul 18 Javascript
对angularJs中自定义指令replace的属性详解
Oct 09 Javascript
了解Javascript中函数作为对象的魅力
Jun 19 Javascript
Vue的transition-group与Virtual Dom Diff算法的使用
Dec 09 Javascript
你准备好迎接vue3.0了吗
Apr 28 Javascript
Vuex实现简单购物车
Jan 10 Vue.js
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通过文件流方式复制文件的方法
2015/03/13 PHP
PHP将Excel导入数据库及数据库数据导出至Excel的方法
2015/06/24 PHP
php通过获取头信息判断图片类型的方法
2015/06/26 PHP
Zend Framework创建自己的动作助手详解
2016/03/05 PHP
PHP实现批量修改文件名的方法示例
2019/09/18 PHP
不同的jQuery API来处理不同的浏览器事件
2012/12/09 Javascript
javascript的解析执行顺序在各个浏览器中的不同
2014/03/17 Javascript
Jquery基础之事件操作详解
2016/06/14 Javascript
Angular设置title信息解决SEO方面存在问题
2016/08/19 Javascript
JavaScript中cookie工具函数封装的示例代码
2016/10/11 Javascript
如何清除IE10+ input X 文本框的叉叉和密码输入框的眼睛图标
2016/12/21 Javascript
Javascript 实现匿名递归的实例代码
2017/05/25 Javascript
vue+webpack 打包文件 404 页面空白的解决方法
2018/02/28 Javascript
Vue 源码分析之 Observer实现过程
2018/03/29 Javascript
VuePress 快速踩坑小结
2019/02/14 Javascript
Vue中的nextTick作用和几个简单的使用场景
2021/01/25 Vue.js
[01:01:18]VP vs NIP 2019国际邀请赛小组赛 BO2 第二场 8.15
2019/08/17 DOTA
python持久性管理pickle模块详细介绍
2015/02/18 Python
解决phantomjs截图失败,phantom.exit位置的问题
2018/05/17 Python
python内置数据类型之列表操作
2018/11/12 Python
利用selenium爬虫抓取数据的基础教程
2019/06/10 Python
树莓派+摄像头实现对移动物体的检测
2019/06/22 Python
Python Tornado之跨域请求与Options请求方式
2020/03/28 Python
Python3.7将普通图片(png)转换为SVG图片格式(网站logo图标)动起来
2020/04/21 Python
Mysql数据库反向生成Django里面的models指令方式
2020/05/18 Python
python3.9实现pyinstaller打包python文件成exe
2020/12/13 Python
html5中地理位置定位api接口开发应用小结
2013/01/04 HTML / CSS
解释一下钝化(Swap out)
2016/12/26 面试题
历史专业个人求职信范文
2013/12/07 职场文书
建筑装饰学院室内设计专业个人自我评价
2013/12/07 职场文书
村官工作鉴定评语
2014/01/27 职场文书
求职信结尾怎么写
2014/05/26 职场文书
品质口号大全
2014/06/17 职场文书
2019企业文化管理制度范本!
2019/08/06 职场文书
五年级作文之劳动作文
2019/11/12 职场文书
动态规划之使用备忘录来改进Javascript函数
2022/04/07 Javascript