幸运抽奖

    var oPointer=document.getElementsByTagName("img")[0];var oTurnable=document.getElementsByTagName("img")[1];var cat=15;//每个区域15度,一共24个区域var num=0;var offOn=true;//是否正在抽奖//指针点击事件,开始抽奖oPointer.onclick=function(){if(offOn){oTurnable.style.transform="rotate(0deg)";offOn=!offOn;ratating();}}//旋转function ratating(){var timer=null;var rdm=0;//随机度数clearInterval(timer);timer=setInterval(function(){if(Math.floor(rdm/360)<3){rdm=Math.floor(Math.random()*3600);}else{oTurnable.style.transform="rotate(" rdm "deg)";clearInterval(timer);setTimeout(function(){offOn=!offOn;num=rdm60;
//                    转盘逆时针的角度为正值if(num<=cat*1){alert("四等奖");console.log("rdm=" rdm ",num=" num "," "四等奖");}else if(num<=cat*2){alert("周君记");console.log("rdm=" rdm ",num=" num "," "周君记");}else if(num<=cat*3){alert("二等奖");console.log("rdm=" rdm ",num=" num "," "二等奖");}else if(num<=cat*4){alert("周君记");console.log("rdm=" rdm ",num=" num "," "周君记");}else if(num<=cat*5){alert("三等奖");console.log("rdm=" rdm ",num=" num "," "三等奖");}else if(num<=cat*6){alert("四等奖");console.log("rdm=" rdm ",num=" num "," "四等奖");}else if(num<=cat*7){alert("幸运奖");console.log("rdm=" rdm ",num=" num "," "幸运奖");}else if(num<=cat*8){alert("周君记");console.log("rdm=" rdm ",num=" num "," "周君记");}else if(num<=cat*9){alert("一等奖");console.log("rdm=" rdm ",num=" num "," "一等奖");}else if(num<=cat*10){alert("周君记");console.log("rdm=" rdm ",num=" num "," "周君记");}else if(num<=cat*11){alert("幸运奖");console.log("rdm=" rdm ",num=" num "," "幸运奖");}else if(num<=cat*12){alert("四等奖");console.log("rdm=" rdm ",num=" num "," "四等奖");}else if(num<=cat*13){alert("三等奖");console.log("rdm=" rdm ",num=" num "," "三等奖");}else if(num<=cat*14){alert("周君记");console.log("rdm=" rdm ",num=" num "," "周君记");}else if(num<=cat*15){alert("二等奖");console.log("rdm=" rdm ",num=" num "," "二等奖");}else if(num<=cat*16){alert("周君记");console.log("rdm=" rdm ",num=" num "," "周君记");}else if(num<=cat*17){alert("四等奖");console.log("rdm=" rdm ",num=" num "," "四等奖");}else if(num<=cat*18){alert("幸运奖");console.log("rdm=" rdm ",num=" num "," "幸运奖");}else if(num<=cat*19){alert("周君记");console.log("rdm=" rdm ",num=" num "," "周君记");}else if(num<=cat*20){alert("幸运奖");console.log("rdm=" rdm ",num=" num "," "幸运奖");}else if(num<=cat*21){alert("四等奖");console.log("rdm=" rdm ",num=" num "," "四等奖");}else if(num<=cat*22){alert("三等奖");console.log("rdm=" rdm ",num=" num "," "三等奖");}else if(num<=cat*23){alert("周君记");console.log("rdm=" rdm ",num=" num "," "周君记");}else if(num<=cat*24){alert("幸运奖");

                        console.log("rdm=" rdm ",num=" num "," "幸运奖");}},4000);}},30);}

 

  #bg{width: 650px;height: 600px;margin:0 auto;background: url(turnable-bg.jpg) no-repeat;position:relative;}/*img从alt开始匹配,直到pointer结束为止*/img[alt="pointer"]{position:absolute;top:125px;left:310px;z-index:10;}img[alt="turnable"]{position:absolute;z-index:5;top:50px;left:80px;transition:all 4s;}

 

<div id="bg"><img src="指针.png" alt="pointer" width="31px" height="182px"><img src="转盘.png" alt="turnable" width="496px" height="500px">
</div>

 抽奖代码里要注意一个地方,就是转动角度:在计算机语言里,逆时针的转动才算是正方向,而顺时针为负方向。

总结步骤:1.找好图片素材,当然也可以自己设计一个。(圆盘和指针)

                  2.先用html将素材写至页面当中。

                  3.设置好样式,呈现好看的页面效果。

                  4.最重要的部分就是在js这块的实现部分:

.                         (1)点击事件;

                           (2)旋转度数的设置(间歇调用,判断语句)

      效果如下:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/369285.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

linux usleep 线程控制权_linux多线程同步—信号量

linux多线程编程-信号量信号量机制锁机制使用是有限制的&#xff0c;锁只有两种状态&#xff0c;即加锁和解锁&#xff0c;对于互斥的访问一个全局变量&#xff0c;这样的方式还可以对付&#xff0c;但是要是对于其他的临界资源&#xff0c;比如说多台打印机等&#xff0c;这种…

Django字段类型介绍

一&#xff0c;通过makemigrations&#xff0c;migrate来修改数据&#xff0c; 1.Django的ORM支持修改表结构&#xff0c;修改完以后&#xff0c;执行 python manage.py makemigrations python manage.py migrate 这两句&#xff0c;就会看到更新了。超过长度的数据就会丢了。…

input输入框的input事件和change事件

input输入框的onchange事件&#xff0c;要在 input 失去焦点的时候才会触发&#xff1b; 在输入框内容变化的时候不会触发change&#xff0c;当鼠标在其他地方点一下才会触发&#xff1b; onchange 事件也可用于单选框与复选框改变后触发的事件。 demo如下&#xff1a; <sc…

单例设计模式–内省和最佳实践

定义&#xff1a; Singleton是“ 四人帮”设计模式的一部分&#xff0c;它属于创新设计模式。 在本文中&#xff0c;我们将更深入地研究Singleton模式的用法。 就建模而言&#xff0c;它是最简单的设计模式之一&#xff0c;但另一方面&#xff0c;就使用的复杂性而言&#xff0…

修改用户名_Word办公技巧:如何更改文档修订者的用户名?

在一份文档需要多人参与修订的时候,每个审阅者将用户名改为自己的名字就可以方便地看出具体哪个参与者做了哪些改动。下面我们来学习一下更改修订者用户名的办法。 应用场景 下图文档中默认修订者用户名为"AutoBVT",接下来我们想将其改为"李小白"。 操作…

Java伪随机数生成器(PRNG)中的弱点

这将是Kai Michaelis&#xff0c;JrgSchwenk和我撰写的论文的总结&#xff0c;该论文在RSA Conference 2013的密码学家会议上发表 。 你可以得到我的演讲的幻灯片在这里和我们的全文在这里 。 我们对PRNG&#xff08;主要是SecureRandom&#xff09;附带的常见Java库生成的随机…

vue安装概要以及vue测试工具

一、概述 1、安装node&#xff0c;去node官网 2、新建一个项目&#xff0c;通过npm init命令初始化&#xff0c;即创建一个package.json文件 3、用命令 npm install vue -g 全局安装vue&#xff08;网上已经有详细的资料&#xff0c;在此就不复述了&#xff09; 二、vue测试…

linux安装与远程连接

1、在VMware上创建新的虚拟机&#xff0c;保证有linux版本的iso镜像文件 具体参考http://jingyan.baidu.com/article/eae0782787b4c01fec548535.html 2、进行切换用户 进行root用户的切换&#xff1a;   #su password: 进行普通用户的切换&#xff1a; #su username 3、编辑…

Spring框架:三种Spring Bean生命周期技术

当使用术语“生命周期”时&#xff0c;Spring的家伙指的是您的bean的构造和破坏&#xff0c;通常这与Spring Context的构造和破坏有关。 在某些情况下&#xff0c;Bean生命周期的管理不是一件容易的事&#xff0c;因为需要它执行自己的内部设置。 当您的bean必须与外部系统进行…

wincc客户机打开服务器文件通讯不上,wincc客户机连不上服务器

如果你计算机名称改正确了&#xff0c;检查一下安装OPC服务软件吗&#xff1f;比如SIMATIC NET。然后试一试下面方法能否解决:首先&#xff0c;设置一下PG/PC接口。方法:开始--设置--控制面板--设置PG/PC接口&#xff0c;在接口分配参数&#xff0c;选择你要的参数(根据你的情…

spring boot高性能实现二维码扫码登录(上)——单服务器版

前言 目前网页的主流登录方式是通过手机扫码二维码登录。我看了网上很多关于扫码登录博客后&#xff0c;发现基本思路大致是&#xff1a;打开网页&#xff0c;生成uuid&#xff0c;然后长连接请求后端并等待登录认证相应结果&#xff0c;而后端每个几百毫秒会循环查询数据库或r…

查看 固态硬盘位置_3米防摔+人脸/指纹解锁:西数Armorlock移动固态硬盘

要求快速而又安全的数据拷贝工具&#xff1f;指纹识别移动SSD大家应该都见过了&#xff0c;今天西数推出了一个更为特别的人脸/指纹识别加密移动SSD。G-Technology Armorlock使用AES256全盘加密固态硬盘中的数据&#xff0c;解锁方式不是常见的密码或自带指纹传感器&#xff0c…

web前端工程师全套教程免费分享

这是我自己早前听课时整理的前端全套知识点&#xff0c;适用于初学者&#xff0c;也可以适用于中级的程序员&#xff0c;你们可以下载下来。我自认为还是比较系统全面的&#xff0c;可以抵得上市场上90%的学习资料。讨厌那些随便乱写的资料还有拿出来卖钱的人&#xff01;在这里…

mybatis一对一联表查询的两种常见方式

1.一条语句执行查询&#xff08;代码如下图&#xff09; 注释&#xff1a;class表&#xff08;c别名&#xff09;&#xff0c;teacher表&#xff08;t别名&#xff09;teacher_id为class表的字段t_id为teacher表的字段&#xff0c;因为两者有主键关联的原因&#xff0c;c_id为c…

在Windows 7中设置Java开发环境

一段时间以来&#xff0c;我收到了很多愿意尝试Java语言的学生和人们的要求&#xff0c;它们提供了关于如何设置Java开发环境的简单指南&#xff0c;类似于我一年前写的那样。 Mac用户。 看到这里和这里 。 因此&#xff0c;本文主要针对Java开发新手&#xff0c;他们寻求有关使…

写给想成为前端工程师的同学们―前端工程师是做什么的?

前端工程师是做什么的&#xff1f; 前端工程师是互联网时代软件产品研发中不可缺少的一种专业研发角色。从狭义上讲&#xff0c;前端工程师使用 HTML、CSS、JavaScript 等专业技能和工具将产品UI设计稿实现成网站产品&#xff0c;涵盖用户PC端、移动端网页&#xff0c;处理视觉…

逆水寒服务器维护7.5,逆水寒7.26日维护到什么时候 逆水寒7.26日游戏改动汇总介绍...

逆水寒7.26日维护到什么时候 逆水寒7.26日游戏改动汇总介绍2018-07-26 10:08:08来源&#xff1a;游戏下载编辑&#xff1a;苦力趴评论(0)《逆水寒》官方发布微博&#xff0c;称为了保证服务器的运行稳定和服务质量&#xff0c;将于7月26日上午7:00-上午10:00进行停服维护。此次…

是否可以限制蓝牙传输距离_技术文章—关于蓝牙传输范围的常见误解

蓝牙技术在耳机、手机、手表及汽车领域的普及为人们带来了许多便利&#xff0c;却也引发了一些人们对于蓝牙的误解。目前&#xff0c;蓝牙可为多种重要的解决方案提供支持&#xff0c;其中包括家庭自动化、室内导航以及商业和工业创新等。误解一&#xff1a;蓝牙稳定传输的最远…

基于webpack搭建的vue element-ui框架

花了1天多的时间&#xff0c; 终于把这个框架搭建起来了。 好了&#xff0c; 不多说了&#xff0c; 直接进入主题了。前提是安装了nodejs,至于怎么安装&#xff0c; 网上都有教程。 这里就不多说了&#xff0c; 这边使用的IDE是idea。1.在E:/my-project&#xff08;我的电脑上&…

编译打包vue_Vue 源码分析( 一 )

Vue 源码分析&#xff08; 一 &#xff09;目录结构、版本、入口1、Vue 源码目录结构dist&#xff1a;打包之后生成的结果目录 examples&#xff1a;代码示例 scripts&#xff1a;配置文件 src&#xff1a;源代码目录compiler: 编译相关 &#xff08;将template模板转换成rende…