js轮盘抽奖实例分析


Posted in Javascript onApril 17, 2020

现在学习到了过渡效果了,已经开始有做动画效果的意识了,会实现一些比较炫的小玩意,一个网页加入过渡动画效果,会让人看起来很有美观,不僵硬,有看头,动画是一个网页美观的主要体现之一,下面做个使用个过渡效果实现的抽奖例子。

先来效果图: 

js轮盘抽奖实例分析

这个的实现需要使用到一些js代码。

所需图片:

js轮盘抽奖实例分析

这张图是pointer.png的位置的。

js轮盘抽奖实例分析

turntable-bg.jpg这张是背景图,在背景位置。

js轮盘抽奖实例分析

这张是turntable.png位置的。  

需要这三张图片,如果要实现一下,直接另存这三图片引入进去即可。如果不会请修改成对应的图片名字,放到同一个文件下。

代码: 

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>抽奖</title>
 <!-- 这里是css部分 -->
 <style>
 #bg{
 width: 650px;
 height: 600px;
 margin: 0 auto;
 background: url(turntable-bg.jpg) no-repeat;
 position: relative;
 }
 img[src^="pointer"]{
 position: absolute;
 z-index: 10;
 top: 155px;
 left: 247px;
 }
 img[src^="turntable"]{
 position: absolute;
 z-index: 5;
 top: 60px;
 left: 116px;
 transition: all 4s;
 }
 
 </style>
</head>
<body>
<!-- 这里是HTML结构部分 -->
 <div id="bg">
 <img src="pointer.png" alt="pointer">
 <img src="turntable.png" alt="turntable">
 </div>
 <!-- 这里是js部分 -->
 <script>
 var oPointer=document.getElementsByTagName("img")[0];
 var oTurntable=document.getElementsByTagName("img")[1];
 var cat=51.4;
 var num=0;
 var offOn=true;
 document.title="";
 
 oPointer.onclick=function(){
 if(offOn){
 oTurntable.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{
 oTurntable.style.transform="rotate("+rdm+"deg)";
 clearInterval(timer);
 setTimeout(function(){
 offOn=!offOn;
 num=rdm%360;
 if(num<=cat*1){
 alert("4999元");
 }else if(num<=cat*2){
 alert("条50元");
 }else if(num<=cat*3){
 alert("10元");
 }else if(num<=cat*4){
 alert("5元");
 }else if(num<=cat*5){
 alert("免息服务");
 }else if(num<=cat*6){
 alert("提交白金");
 }else if(num<=cat*7){
 alert("未中奖");
 }
 },4000);
 } 
 },30); 
 }
 </script>
</body>
</html>

css和HTML代码不多,主要是为了实现过渡设置,还有为了实现层叠而使用position定位,让元素脱离文档流,js代码在于获取元素和事件的点击,点击指针会旋转,所以要给指针加个点击事件,然后是判断旋转是否停止,如果没有就点击也不能调用函数ratating(),这个函数执行转盘的旋转和判断指针停在什么位置,然后弹出相应的内容,而函数里实现旋转的过程,是获取转盘的元素,然后使用js控制css的属性-transform:rotate(),我们不是使用过这个属性在css里直接使它实现旋转的效果吗?就是和伪类选择器:hover及过渡属性一起使用去实现的,那么因为css实现不了数字的运算和鼠标点击,所以让js去实现且控制css属性,实现到点击旋转这个功能,然而定时器的使用暂时不说,思路就是使用js实现数字的运算和鼠标的点击及css属性的控制达到旋转的效果。

Math.random()是随机数的生成,Math.floor()向下取整。

想要学习更多关于抽奖功能的实现,请参考此专题:抽奖功能

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

Javascript 相关文章推荐
js不完美解决click和dblclick事件冲突问题
Jul 16 Javascript
IE不支持getElementsByClassName最终完美解决方案
Dec 17 Javascript
jQuery快速上手:写jQuery与直接写JS的区别详细解析
Aug 26 Javascript
js对象转json数组的简单实现案例
Feb 28 Javascript
js隐式全局变量造成的bug示例代码
Apr 22 Javascript
使用jQuery不判断浏览器高度解决iframe自适应高度问题
Dec 16 Javascript
在iframe中使bootstrap的模态框在父页面弹出问题
Aug 07 Javascript
详解layui中的树形关于取值传值问题
Jan 16 Javascript
jQuery中元素选择器(element)简单用法示例
May 14 jQuery
layui-laydate时间日历控件使用方法详解
Nov 15 Javascript
原生js+css调节音量滑块
Jan 15 Javascript
通过滑动翻页效果实现和移动端click事件问题
Jan 26 Javascript
JavaScript 中有关数组对象的方法(详解)
Aug 15 #Javascript
onmouseover事件和onmouseout事件全面理解
Aug 15 #Javascript
浅谈toLowerCase和toLocaleLowerCase的区别
Aug 15 #Javascript
又一款js时钟!transform实现时钟效果
Aug 15 #Javascript
最丑的时钟效果!js canvas时钟制作方法
Aug 15 #Javascript
深入分析javascript中console命令
Aug 14 #Javascript
Vue.js 表单校验插件
Aug 14 #Javascript
You might like
MySQL中create table语句的基本语法是
2007/01/15 PHP
PHP使用ODBC连接数据库的方法
2015/07/18 PHP
PHP预定义变量9大超全局数组用法详解
2016/04/23 PHP
PHP未登录自动跳转到登录页面
2016/12/21 PHP
JQuery 学习技巧总结
2010/05/21 Javascript
jQuery Select(单选) 模拟插件 V1.3.62 改进版
2010/07/17 Javascript
Firebug入门指南(Firefox浏览器)
2010/08/21 Javascript
jQuery easyui datagrid动态查询数据实例讲解
2013/02/26 Javascript
js鼠标及对象坐标控制属性详细解析
2013/12/14 Javascript
JavaScript日期时间格式化函数分享
2014/05/05 Javascript
使用JS画图之点、线、面
2015/01/12 Javascript
AngularJS内置指令
2015/02/04 Javascript
JS实现仿FLASH效果的竖排导航代码
2015/09/15 Javascript
jQuery实现仿QQ在线客服效果的滚动层代码
2015/10/15 Javascript
原生javascript实现图片无缝滚动效果
2016/02/12 Javascript
老生常谈javascript中逻辑运算符&amp;&amp;和||的返回值问题
2017/04/13 Javascript
vue jsx 使用指南及vue.js 使用jsx语法的方法
2017/11/11 Javascript
基于 Vue 实现一个酷炫的 menu插件
2017/11/14 Javascript
JS实现快递单打印功能【推荐】
2018/06/21 Javascript
vue router总结 $router和$route及router与 router与route区别
2019/07/05 Javascript
Vue实现多标签选择器
2019/11/28 Javascript
[55:18]Liquid vs Chaos 2019国际邀请赛小组赛 BO2 第一场 8.15
2019/08/16 DOTA
用Python编写一个国际象棋AI程序
2014/11/28 Python
Python爬虫模拟登录带验证码网站
2016/01/22 Python
Python Sql数据库增删改查操作简单封装
2016/04/18 Python
Python实现的弹球小游戏示例
2017/08/01 Python
Python获取当前函数名称方法实例分享
2018/01/18 Python
使用python实现http及ftp服务进行数据传输的方法
2018/10/26 Python
解决Pycharm后台indexing导致不能run的问题
2019/06/27 Python
Django 项目重命名的实现步骤解析
2019/08/14 Python
Python通过TensorFLow进行线性模型训练原理与实现方法详解
2020/01/15 Python
python 项目目录结构设置
2020/02/14 Python
印尼最大的网上书店:Gramedia.com
2018/09/13 全球购物
一些高难度的SQL面试题
2016/11/29 面试题
员工考核评语大全
2014/04/26 职场文书
基于nginx实现上游服务器动态自动上下线无需reload的实现方法
2021/03/31 Servers