前端随机抽奖效果

news2025/2/26 8:03:28

功能描述

开始随机、标签收取、重置布局、标签收取后添加标记、删除标记、复原标记、重置布局
可以通过此功能实现随机点名、抽奖功能

效果截图

在这里插入图片描述

实现所用技术

vscode编写工具htmlcssjquery

以下为效果代码

<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
	<title></title>
    <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.4/jquery.min.js"></script>
	<style type="">
		*{
			margin:0;
			padding:0;
		}
		#btn-group{
			text-align: center;
			width: 1000px;
			padding: 20px;
		}
		#btn-group p{
			padding: 4px 20px;
			font-size: 16px;
			display: inline-block;
			margin-right: 20px;
			color: #fff;
			border: 1px solid #7190c7;
			background: #7190c7;
			transition: 0.3s;
			cursor: pointer;
		}
		#btn-group p:hover{
			color: #fff;
			background: #eaa6a3;
			border-color: transparent;
		}
		ul{
			width:1000px;
			margin:0 0 0 20px;
			padding: 10px 20px 30px;
			border: 2px solid #f1ccb8;
			display: flex;
			flex-wrap: wrap;
			justify-content: space-between;
			background: #ffd;
		}
		ul li{
			list-style: none;
			width: 100px;
			height: 40px;
			font-size: 23px;
			text-align: center;
			line-height: 40px;
			color: #f1f1f1;
			background: #3499ad;
			margin: 10px;
			box-sizing: border-box;
			position: relative;
			transition: 0.3s;
		}
		li:hover{
			border-radius: 0;
			/* background: #8094ff; */
    		box-shadow: 0 0 13px 2px white inset;
		}
		.span1,.span2{
			display:inline-block;
			width:30px;
			height:20px;
			margin:0 3px;
			background:#2BF371;
			border-radius:20px 0 20px 0;
			box-shadow: 0 0 8px 1px #04ff00;
			transform: rotate(-20deg);
		}
		u.mark{
			color: red;
			border: 1px solid red;
			transform: rotate(-36deg);
			font-size: 12px;
			position: absolute;
			padding: 4px 6px;
			line-height: 12px;
			text-shadow: 0 0 0 transparent;
		}
		u.mark.new{
			color:#fff;
			border-color:#fff;
			left:-3px;
			background:#000;
		}
		/* 收取标签后-标签放大效果 */
		.active-max{
			width:980px;
			height:400px;
			font-size:100px;
			line-height:200px;
			transition:0.4s;
			text-shadow: 0 0 18px #f6ff67;
			cursor: pointer;
		}
	</style>
</head>
<body>
	<div id="btn-group">
		<p id="startBtn">开始抽取标签</p>
		<p id="getNumBtn">收取标签</p>
		<p id="removeMark">删除标记</p>
		<p id="goMark">还原标记</p>
		<p id="resetBtn">重置布局</p>
	</div>
	<!-- 点名列表 -->
	<ul></ul>
</body>
<script>
	// 标签选中色
	const activeColor = '#ff4040'

	// 移除收取标签后的叶子图案
	function removeLeaf(){
		$('.span1,.span2').remove()/*删除小叶子*/
	}

	// 生成点名列表
	var liList = Array(40).fill(null)
	liList.map((item, index)=>{
		$(`<li>${index+1}</li>`).appendTo('ul')
	})

	var arr = $('li')
	var timer
	var num = 0
	var isStart = false//防止开始、结束按钮连点
	var stor = []//存放标记的存储器
	$('#startBtn').on('click',function(){
		$('li').off('click')
		$('u').css({
			top:5,
			left:0
		})
		removeLeaf()
		arr.eq(num).removeClass('active-max').siblings().css({display:'block'})/*被收取的标签恢复原样*/

		if(!isStart){
			isStart = true

			timer = setInterval(function(){
				num = parseInt(Math.random()*arr.length)
				arr.eq(num).css('background', activeColor)
					.siblings('li').css('background','#3499ad')
			},100)
		}
	})
	
	$('#resetBtn').on('click',function(){
		isStart = false

		stor = []
		$('u').remove()
		
		$('li').off('click')
		$('u').css({
			top:5,
			left:0
		})
		clearInterval(timer)
		removeLeaf()
		arr.eq(num).removeClass('active-max').siblings().css({display:'block'})/*抽取的元素恢复原样*/
		arr.eq(num).css('background','#3499ad')
	})

	$('#getNumBtn').on('click',function(){
		if(isStart){
			isStart = false

			clearInterval(timer)

			// 给抽取的标签插入小样式
			arr.eq(num)
				.addClass('active-max').css('background','#c28164')
				.prepend('<span class="span1"></span>')
				.append('<span class="span2"></span>').siblings()
				.css({
					display:'none'
				})
			// 收取的数字点击可以添加标记效果
			arr.eq(num).click(function(e){
				var x=e.offsetX
				var y=e.offsetY
				$(this).children('u').remove()
				$(this).append('<u class="mark">标记</u>').children('u').css({
					top:y,
					left:x
				})
				stor.push($(this).index())
			})
		}
	})

	$('#removeMark').click(function(){
		$('u').remove()
	})
	$('#goMark').click(function(){
		$.each(stor,function(index,item){
			$('li').eq(item).children('u').remove().end().append('<u class="mark new">标记</u>')
		})
	})
</script>
</html>

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

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

相关文章

JavaScript实现通过语句输出当前星期的代码

以下为实现通过语句输出当前星期的程序代码和运行截图 目录 前言 一、通过语句输出当前星期 1.1 运行流程及思想 1.2 代码段 1.3 JavaScript语句代码 1.4 运行截图 前言 1.若有选择&#xff0c;您可以在目录里进行快速查找&#xff1b; 2.本博文代码可以根据题目要求实…

跟我看 Microsoft Build 2023

又是一年一度的 Microsoft Build 了&#xff0c;你有和我一样熬夜看了吗&#xff1f;如果没有&#xff0c;那么你就错过了一场精彩的技术盛宴。本次的 Microsoft Build &#xff0c;有非常多的干货&#xff0c;围绕打造 Copilot 应用展开。我会将基于 Data AI 比较重要的内容列…

chatgpt赋能Python-python_nonzero

Python的nonzero函数 - 了解它的作用和实际应用 在Python编程语言中&#xff0c;有一个非常有用的函数叫做nonzero()&#xff0c;该函数通常被使用来检测列表、元组、数组和字典等数据结构中的非零值。本文将详细介绍nonzero()函数的特性和实际应用场景。 了解nonzero函数的作…

17.plantUML画类图的语法、组合关系和聚合关系之间的区别

文章目录 plantUML画类图的语法组合关系和聚合关系之间的区别依赖关系和关联关系的区别一个类图语法示例 plantUML画类图的语法 泛化关系就是继承关系 语法解释&#xff1a;<|-- 表示组合&#xff0c;<|-表示继承 表示 public&#xff0c; #表示protect - 表示 private…

chatgpt赋能Python-python_owl

Python Owl: 一个优秀的Python工具库&#xff0c;优化你的SEO体验 如果你是一个SEO专家&#xff0c;你肯定会知道Python Owl这个工具库是什么。如果你还不知道&#xff0c;那么你来对地方了。Python Owl是一个强大的Python工具库&#xff0c;能够帮助你优化你的SEO体验&#x…

对讲机怎么提高通话距离?

对讲机的理论通讯距离一般都比较远&#xff0c;只不过在实际的应用当中会受到多方面的影响&#xff0c;比如建筑物、树林、山体等。那么我们该怎么提高对讲机的通话距离呢&#xff1f;下面河南宝蓝小编就为大家分析下。 一、提高发射功率&#xff1a; 基本上所有的对讲机都有…

【数据结构】树和二叉树和基本介绍、树的基本术语和表示、二叉树的性质和储存结构

文章目录 1.树的基本概念和介绍1.1树的概念1.2树的基本术语1.3树的使用1.4树的表示1.4.1图形表示1.4.2代码表示 2.二叉树的基本概念和介绍2.1二叉树的介绍2.2二叉树的性质2.3二叉树的储存结构2.3.1顺序储存结构2.3.2链式存储结构 1.树的基本概念和介绍 1.1树的概念 在以前的学…

springBoo3.0集成knife4j4.1.0(swagger3)

温馨提示&#xff1a; springBoot 版本 3.0 knife4j 版本 4.1.0 添加依赖&#xff1a;knife4j包含了swagger&#xff0c;openapi3中的依赖&#xff0c;所以加这一个就行。 <dependency><groupId>com.github.xiaoymin</groupId><artifactId>knife4j-op…

Seata AT 模式理论学习、事务隔离及部分源码解析 | Spring Cloud 52

理论部分来自Seata官网&#xff1a;http://seata.io/zh-cn/docs/dev/mode/at-mode.html 一、前提 基于支持本地 ACID 事务的关系型数据库。Java 应用&#xff0c;通过 JDBC 访问数据库。 二、整体机制 两阶段提交协议的演变&#xff1a; 一阶段&#xff1a;业务数据和回滚日…

算法设计与分析:数理基础与串匹配程序设计

目录 前言实验内容实验流程实验过程实验分析伪代码代码实现分析算法复杂度用例测试 总结 前言 本实验是算法设计与分析课程的一个实验&#xff0c;旨在帮助掌握数理基础和串匹配算法的相关知识&#xff0c;以及如何用C语言实现串匹配程序。本实验分为两个部分&#xff1a;第一…

【Leetcode -643.子数组最大平均值Ⅰ -645.错误的集合】

Leetcode Leetcode -643.子数组最大平均值ⅠLeetcode -645.错误的集合 Leetcode -643.子数组最大平均值Ⅰ 题目&#xff1a;给你一个由 n 个元素组成的整数数组 nums 和一个整数 k 。 请你找出平均数最大且长度为 k 的连续子数组&#xff0c;并输出该最大平均数。 任何误差小…

Buildroot 切换到国内源

可以在make menuconfig的界面里的Build options–>Mirrors and Download locations中的几个地址依次填入下面几个国内的加速镜像源url地址&#xff0c;速度可以快非常多&#xff01;&#xff01; BACKUP_SITE"http://sources.buildroot.net" KERNEL_MIRROR"…

linux消息队列总结

消息队列&#xff0c;是消息的链接表&#xff0c;存放在内核中。一个消息队列由一个标识符(即队列ID) 来标识 1、特点 &#xff08;1&#xff09;消息队列是面向记录的&#xff0c;其中的消息具有特定的格式以及特定的优先级 &#xff08;2&#xff09;消息队列独立于发送与接收…

chatgpt赋能Python-python_pendown

Python PenDown: 一个简单易用的MarkDown编辑器 在现代化的互联网环境下&#xff0c;搜索引擎优化已经成为了每个网站都必须要面对的问题&#xff0c;而一个网站的SEO质量往往与网站的内容相关。而MarkDown则是现代网络环境下非常受欢迎的一种文本标记语言&#xff0c;因为其语…

数据仓库漫谈-前世今生

数据仓库的内容非常多&#xff0c;每一个子模块拎出来都能讲很久。这里没法讲太多细节&#xff0c;大致思考了三个备选议题&#xff1a; 数据仓库的前世今生 数据仓库体系知识介绍 数仓开发者的路在何方&#xff1f; 既然是第一次分享&#xff0c;感觉还是跟大家普及下数仓的…

百度营销:百度扩量投放技巧

众所周知百度是国内大部分用户都在使用的搜索引擎。百度搜索投放的是关键词形式。今天将带来一些账户优化的建议。放量模式共享预算有哪些投放细节呢&#xff1f;以下梳理了5个小技巧&#xff1a; 1.适合的账户类型 更适合预算充足的广告主。如果当前&#xff0c;你每天的获客…

shell编程快捷命令

shell编程快捷命令 一、快捷排序 — sort 命令二、快捷去重 — uniq 命令三、快捷替换 — tr 命令四、快速裁剪 — cut 命令五、文件拆分 — split 命令七、变量扫描器 — eval 命令 一、快捷排序 — sort 命令 sort命令用于以行为单位&#xff0c;对文件的内容进行排序 语法格…

【轻量化网络系列(3)】MobileNetV3论文超详细解读(翻译 +学习笔记+代码实现)

前言 上周我们学习了MobileNetV1和MobileNetV2&#xff0c;本文的MobileNetV3&#xff0c;它首先引入MobileNetV1的深度可分离卷积&#xff0c;然后引入MobileNetV2的具有线性瓶颈的倒残差结构&#xff0c;后来使用了网络搜索算法&#xff0c;并引入了SE模块以及H-Swish激活函…

Vue监视属性

1&#xff0c;click事件的属性可以些什么&#xff1f; 答&#xff1a;click即click"xxx"&#xff0c;其中xxx可以是一个methods方法&#xff0c;也可以是一些简单的语句&#xff0c;比如i&#xff0c;i<0&#xff1f;250 : 520。即click"add&#xff1b;i&am…

【数据结构】---堆排序:时间复杂度高于(N*logN)的排序别来沾边

文章目录 前言&#x1f31f;一、建堆的两种方式&#xff1a;&#x1f30f;1.1 向上调整建堆(堆排序)&#xff1a;&#x1f4ab;1.1.1 完整代码&#xff1a;&#x1f4ab;1.1.2 流程图(以小堆为例)&#xff1a;升序&#xff1a;建大堆&#x1f4ab;1.1.3 流程图(以小堆为例)&…