原生JS实现九宫格抽奖效果

作者:完美续航 时间:2024-04-17 10:33:38 

效果图:

原生JS实现九宫格抽奖效果

代码如下:


<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<title></title>
<style>
*{margin:0;padding:0;}
#container{width:310px;height:310px;margin:30px auto;}
#ul1{width:310px;height:310px;list-style:none;}
#ul1 li,#ul1 a{width:100px;height:100px;border:1px solid #565656;float:left;text-align:center;line-height:100px;}
#ul1 a:hover{cursor:pointer;color:orange;font-size:18px;}
#ul1 .active{background:red;color:#fff;}
#pp{line-height:32px;color:#9a9a9a;text-align:center;}
</style>
</head>
<body>
<div id="container">
<ul id="ul1">
<li>一等奖</li>
<li>二等奖</li>
<li>三等奖</li>
<li>四等奖</li>
<a>开始</a>
<li>五等奖</li>
<li>六等奖</li>
<li>七等奖</li>
<li>八等奖</li>
</ul>
<p id="pp"></p>
</div>
<script>
var container = document.getElementById('container'),
li = container.getElementsByTagName('li'),
aa = container.getElementsByTagName('a')[0],
pp = document.getElementById('pp'),
timer = null;
function start(){
var i = 0;
var num = Math.floor(Math.random() * li.length) + 20;
if(i<num){
timer = setInterval(function(){
for(var j=0;j<li.length;j++){
 li[j].className = '';
}
li[i%li.length].className = 'active';
i++;
if(i === num){
 clearInterval(timer);
 if(num%li.length === 0){
 pp.innerHTML += "恭喜您中了:8 等奖" + '<br/>';
 }else{
 pp.innerHTML += "恭喜您中了:"+ parseInt(num%li.length) + " 等奖"+ '<br/>';
 }
}
},130);
}
}
aa.onclick = function(){
start();
}
</script>
</body>
</html>

来源:http://www.qdfuns.com/notes/40961/8faeb4cd96ee77b45bb62751bec7e413.html

标签:js,抽奖
0
投稿

猜你喜欢

  • 如何在vue中使用ant-design-vue组件

    2024-05-02 16:32:47
  • 在Internet Explorer中正确使用MSXML

    2009-02-22 18:41:00
  • python切片的步进、添加、连接简单操作示例

    2022-09-10 01:26:34
  • Websocket通信协议在数字孪生中的应用

    2024-04-30 08:55:46
  • 详解python中 os._exit() 和 sys.exit(), exit(0)和exit(1) 的用法和区别

    2023-11-20 14:14:52
  • python可以美化表格数据输出结果的两个工具

    2022-06-05 02:33:32
  • 如何通过IntersectionObserver实现懒加载

    2024-04-16 08:44:41
  • 有关Python的22个编程技巧

    2021-04-05 22:58:05
  • Web标准基础教程:CSS简写指南

    2010-04-02 12:47:00
  • MySQL数据库常用命令小结

    2024-01-15 22:16:31
  • python使用for循环和海龟绘图实现漂亮螺旋线

    2023-08-01 10:38:57
  • haskell实现多线程服务器实例代码

    2021-08-06 00:08:22
  • 对Web开发人员有用的8个网站小结

    2022-01-16 09:39:20
  • Python grequests模块使用场景及代码实例

    2021-08-05 18:30:41
  • PHP实现多文件上传的方法

    2023-11-23 03:42:04
  • 获取django框架orm query执行的sql语句实现方法分析

    2021-06-08 08:37:41
  • Python ArgumentParse的subparser用法说明

    2022-08-15 08:41:02
  • 浅谈python下tiff图像的读取和保存方法

    2021-11-23 04:10:08
  • Persits AspJpeg 1.8+ 轻松实现透明文字去锯齿水印

    2009-03-20 14:03:00
  • 如何使用SQLServer数据库查询累计值

    2009-03-16 14:43:00
  • asp之家 网络编程 m.aspxhome.com