jquery.rotate.js实现可选抽奖次数和中奖内容的转盘抽奖代码
需求:
抽奖代码最多可以抽奖5次,而且,每次只会中“2000元理财金”或者“谢谢参与”,其它的不会抽中(哈哈,果然都是套路)。
效果如下:
一、页面结构:
1
2
3
4
5
6
7
8
9
10
11
12
|
<div class= "g-content" > <div class= "g-lottery-case" > <div class= "g-left" > <h2>您已拥有<span class= "playnum" ></span>次抽奖机会,点击立刻抽奖!~</h2> <div class= "g-lottery-box" > <div class= "g-lottery-img" > </div> <a class= "playbtn" href= "javascript:;" rel= "external nofollow" rel= "external nofollow" title= "开始抽奖" ></a> </div> </div> </div> </div> |
标签h2为提示内容,.playnum是剩余抽奖次数,.g-lottery-img是最外层的闪灯,.g-lottery-img是转动的内容,.playbtn是点击抽奖按钮。
这里用的是jquery.rotate.js,所以要引入jquery然后引入jquery.rotate.js,百度一下很简单的,没几个AIP。
二、简单的样式:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
|
<style> .g-content { width: 100%; background: #fbe3cc; height: auto; font-family: "微软雅黑" , "microsoft yahei" ; } .g-content .g-lottery- case { width: 500px; margin: 0 auto; overflow: hidden; } .g-content .g-lottery- case .g-left h2 { font-size: 20px; line-height: 32px; font-weight: normal; margin-left: 20px; } .g-content .g-lottery- case .g-left { width: 450px; float: left; } .g-lottery-box { width: 400px; height: 400px; margin-left: 30px; position: relative; background: url(ly-plate-c.gif) no-repeat; } .g-lottery-box .g-lottery-img { width: 340px; height: 340px; position: relative; background: url(bg-lottery.png) no-repeat; left: 30px; top: 30px; } .g-lottery-box .playbtn { width: 186px; height: 186px; position: absolute; top: 50%; left: 50%; margin-left: -94px; margin-top: -94px; background: url(playbtn.png) no-repeat; } </style> |
样式就定一下高度,居中一下,显示一下背景图片
三、JS代码:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
|
<script> $( function () { var $btn = $( '.g-lottery-img' ); // 旋转的div var playnum = 5; //初始次数,由后台传入 $( '.playnum' ).html(playnum); //显示还剩下多少次抽奖机会 var isture = 0; //是否正在抽奖 var clickfunc = function () { var data = [1, 2, 3, 4, 5, 6]; //抽奖 //data为随机出来的结果,根据概率后的结果 data = data[Math.floor(Math.random() * data.length)]; //1~6的随机数 switch (data) { case 1: rotateFunc(1, 0, '恭喜您获得2000元理财金' ); break ; case 2: rotateFunc(2, 0, '恭喜您获得2000元理财金2' ); break ; case 3: rotateFunc(3, 0, '恭喜您获得2000元理财金3' ); break ; case 4: rotateFunc(4, -60, '谢谢参与4' ); break ; case 5: rotateFunc(5, 120, '谢谢参与5' ); break ; case 6: rotateFunc(6, 120, '谢谢参与6' ); break ; } } $( ".playbtn" ).click( function () { if (isture) return ; // 如果在执行就退出 isture = true ; // 标志为 在执行 if (playnum <= 0) { //当抽奖次数为0的时候执行 alert( "没有次数了" ); $( '.playnum' ).html(0); //次数显示为0 isture = false ; } else { //还有次数就执行 playnum = playnum - 1; //执行转盘了则次数减1 if (playnum <= 0) { playnum = 0; } $( '.playnum' ).html(playnum); clickfunc(); } }); var rotateFunc = function (awards, angle, text) { isture = true ; $btn.stopRotate(); $btn.rotate({ angle: 0, //旋转的角度数 duration: 4000, //旋转时间 animateTo: angle + 1440, //给定的角度,让它根据得出来的结果加上1440度旋转 callback: function () { isture = false ; // 标志为 执行完毕 alert(text); } }); }; }); </script> |
说到底就是用一个1~6的随机数,然后把对应的角度值传给jquery.rotate.js,它就会转到相应的地方,最后做一下对应剩余次数的判断和修改。
最后所有代码为:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
|
<!DOCTYPE html> <html> <head> <meta charset= "utf-8" /> <title>抽奖</title> <meta name= "keywords" content= "" > <meta name= "description" content= "" > <meta http-equiv= "X-UA-Compatible" content= "IE=edge" > <meta name= "renderer" content= "webkit" > <style> .g-content { width: 100%; background: #fbe3cc; height: auto; font-family: "微软雅黑" , "microsoft yahei" ; } .g-content .g-lottery- case { width: 500px; margin: 0 auto; overflow: hidden; } .g-content .g-lottery- case .g-left h2 { font-size: 20px; line-height: 32px; font-weight: normal; margin-left: 20px; } .g-content .g-lottery- case .g-left { width: 450px; float: left; } .g-lottery-box { width: 400px; height: 400px; margin-left: 30px; position: relative; background: url(ly-plate-c.gif) no-repeat; } .g-lottery-box .g-lottery-img { width: 340px; height: 340px; position: relative; background: url(bg-lottery.png) no-repeat; left: 30px; top: 30px; } .g-lottery-box .playbtn { width: 186px; height: 186px; position: absolute; top: 50%; left: 50%; margin-left: -94px; margin-top: -94px; background: url(playbtn.png) no-repeat; } </style> </head> <body> <div class= "g-content" > <div class= "g-lottery-case" > <div class= "g-left" > <h2>您已拥有<span class= "playnum" ></span>次抽奖机会,点击立刻抽奖!~</h2> <div class= "g-lottery-box" > <div class= "g-lottery-img" > </div> <a class= "playbtn" href= "javascript:;" rel= "external nofollow" rel= "external nofollow" title= "开始抽奖" ></a> </div> </div> </div> </div> <script src= "http://libs.baidu.com/jquery/2.1.4/jquery.min.js" ></script> <script type= "text/javascript" src= "jsmin/jquery.rotate.min.js" ></script> <script> $( function () { var $btn = $( '.g-lottery-img' ); // 旋转的div var playnum = 5; //初始次数,由后台传入 $( '.playnum' ).html(playnum); //显示还剩下多少次抽奖机会 var isture = 0; //是否正在抽奖 var clickfunc = function () { var data = [1, 2, 3, 4, 5, 6]; //抽奖 //data为随机出来的结果,根据概率后的结果 data = data[Math.floor(Math.random() * data.length)]; //1~6的随机数 switch (data) { case 1: rotateFunc(1, 0, '恭喜您获得2000元理财金' ); break ; case 2: rotateFunc(2, 0, '恭喜您获得2000元理财金2' ); break ; case 3: rotateFunc(3, 0, '恭喜您获得2000元理财金3' ); break ; case 4: rotateFunc(4, -60, '谢谢参与4' ); break ; case 5: rotateFunc(5, 120, '谢谢参与5' ); break ; case 6: rotateFunc(6, 120, '谢谢参与6' ); break ; } } $( ".playbtn" ).click( function () { if (isture) return ; // 如果在执行就退出 isture = true ; // 标志为 在执行 if (playnum <= 0) { //当抽奖次数为0的时候执行 alert( "没有次数了" ); $( '.playnum' ).html(0); //次数显示为0 isture = false ; } else { //还有次数就执行 playnum = playnum - 1; //执行转盘了则次数减1 if (playnum <= 0) { playnum = 0; } $( '.playnum' ).html(playnum); clickfunc(); } }); var rotateFunc = function (awards, angle, text) { isture = true ; $btn.stopRotate(); $btn.rotate({ angle: 0, //旋转的角度数 duration: 4000, //旋转时间 animateTo: angle + 1440, //给定的角度,让它根据得出来的结果加上1440度旋转 callback: function () { isture = false ; // 标志为 执行完毕 alert(text); } }); }; }); </script> </body> </html> |
所需要的图片(这里好像上传不了压缩文件,所以不能整个打包上传了):
#复制下面的图片名称-鼠标移到图片上-右键-图片另存为-粘贴保存#
1.最外面的闪灯:ly-plate-c.gif
2.六个中奖内容:bg-lottery.png
3.点击抽奖按钮: playbtn.png
jquery.rotate.js实现可选抽奖次数和中奖内容的转盘抽奖代码的更多相关文章
- jquery.rotate.js可选抽奖次数和中奖内容的转盘抽奖demo
需求: 最多可以抽奖5次,而且,每次只会中“2000元理财金”或者“谢谢参与”,其它的不会抽中(哈哈,果然都是套路). 效果如下: 一.页面结构: <div class="g-cont ...
- jQuery.rotate.js(控制图片转动)
jQuery.rotate.js笔记 1. jQuery.rotate.js是什么 一个开源的兼容多浏览器的jQuery插件用来对元素进行任意角度的旋转动画. 这个库开发的目的是为了旋转img的, ...
- jQuery.rotate.js笔记
1. jQuery.rotate.js是什么 一个开源的兼容多浏览器的jQuery插件用来对元素进行任意角度的旋转动画. 这个库开发的目的是为了旋转img的,在3.x之后的版本可能支持其它元素,但旋转 ...
- jquery.rotate.js实现旋转动画
1.页面引入jquery.rotate.js文件, 下载地址:https://files.cnblogs.com/files/zhoujl-5071/jquery.rotate.js(打开这个网址,c ...
- C#保留2位小数几种场景总结 游标遍历所有数据库循环执行修改数据库的sql命令 原生js轮盘抽奖实例分析(幸运大转盘抽奖) javascript中的typeof和类型判断
C#保留2位小数几种场景总结 场景1: C#保留2位小数,.ToString("f2")确实可以,但是如果这个数字本来就小数点后面三位比如1.253,那么转化之后就会变成1.2 ...
- jQuery.rotate.js参数
CSS3 提供了多种变形效果,比如矩阵变形.位移.缩放.旋转和倾斜等等,让页面更加生动活泼有趣,不再一动不动.然后 IE10 以下版本的浏览器不支持 CSS3 变形,虽然 IE 有私有属性滤镜(fil ...
- 原生js轮盘抽奖实例分析(幸运大转盘抽奖)
效果图: 所需图片素材: 这张图是pointer.png的位置的. turntable-bg.jpg这张是转盘背景图,在背景位置. 这张是turntable.png位置的. 需要这三张图片,如果要实现 ...
- jquery.rotate.js库中的rotate函数怎么用。
rotate是jQuery旋转rotate插件,支持Internet Explorer 6.0+ .Firefox 2.0 .Safari 3 .Opera 9 .Google Chrome,高级浏览 ...
- jQuery旋转插件jquery.rotate.js 让图片旋转
演示1 直接旋转一个角度 $('#img1').rotate(45); 演示2 鼠标移动效果 $('#img2').rotate({ bind : { mouseover : function(){ ...
随机推荐
- day13_Mysql事务与数据库连接池学习笔记
一.Mysql事务 事务: 事务指逻辑上的一组操作,组成这组操作的各个单元,要么全部成功,要么全部不成功(数据回滚). 例如:A给B转帐,对应于如下两条sql语句 : update account ...
- Unity3D学习(五):实现一个简单的视觉感知
前言 在很多第一人称或者第三人称射击游戏的单人模式中,玩家的乐趣往往来源于和各式各样的AI敌人的战斗.而战斗的爆发很多时候是因为这些AI在"看见"玩家后就会立即做出反应,比如开火. ...
- MySQL中查询时"Lost connection to MySQL server during query"报错的解决方案
一.问题描述: mysql数据库查询时,遇到下面的报错信息: 二.原因分析: dw_user 表数据量比较大,直接查询速度慢,容易"卡死",导致数据库自动连接超时.... 三.解决 ...
- Boyer-Moore(BM)算法,文本查找,字符串匹配问题
KMP算法的时间复杂度是O(m + n),而Boyer-Moore算法的时间复杂度是O(n/m).文本查找中“ctrl + f”一般就是采用的BM算法. Boyer-Moore算法的关键点: 从右遍历 ...
- mvc上传图片
长时间没有接触mvc,有点生疏了,这次mvc上传图片功能完成后,简单地总结下. 我围绕这三块介绍,首先是前台form表单: <style> #file_name { width: 400p ...
- W3C------JS
✄--------------------------------------------分割线--------------------------------------------✄ W3C:ht ...
- QM1_Time value of Money
总体框架 Time Value Interest Rate rf: 无风险收益率 (CFA中一般认为是美国短期国债T-bill的收益率) Nominal risk-free rate: 名义无风险税 ...
- Java Script 学习笔记 (二) Casper JS
1. click() VS mouse.click() 在写自动化脚本要勾选一个复选框时,用casper.mouse.click() 无法选上这个checkbox, 需要用到casper.click( ...
- []T 还是 []*T, 这是一个问题
全面分析Go语言中的类型和类型指针的抉择 目录 [−] 副本的创建 T的副本创建 *T的副本创建 如何选择 T 和 *T 什么时候发生副本创建 最常见的case map.slice和数组 for-ra ...
- 我TM菜爆
我怎么什么都能爆零啊! 我太神了!