"```markdown
使用HTML5创建刮刮乐奖券布局
1. 基本结构
首先,创建一个基本的HTML结构,包括<!DOCTYPE html>
声明和<html>
,<head>
,<body>
标签。
html
<!DOCTYPE html>
<html lang=\"zh-CN\">
<head>
<meta charset=\"UTF-8\">
<meta name=\"viewport\" content=\"width=device-width, initial-scale=1.0\">
<title>刮刮乐奖券</title>
<link rel=\"stylesheet\" href=\"styles.css\">
</head>
<body>
<div class=\"scratch-card\">
<div class=\"reward\">
<h2>恭喜你!</h2>
<p>你赢得了</p>
<h1>100元现金!</h1>
</div>
<div class=\"scratch-area\"></div>
</div>
<script src=\"script.js\"></script>
</body>
</html>
2. CSS样式
接下来,使用CSS来设计刮刮乐的外观。设置奖券的尺寸、背景颜色、边框和其他样式。
css
/* styles.css */
body {
display: flex;
justify-content: center;
align-items: center;
height: 100vh;
background-color: #f0f0f0;
font-family: Arial, sans-serif;
}
.scratch-card {
width: 300px;
height: 400px;
border: 2px solid #d5d5d5;
border-radius: 10px;
background: linear-gradient(135deg, #f9d423, #ff4e50);
position: relative;
overflow: hidden;
}
.reward {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
text-align: center;
color: white;
}
.scratch-area {
width: 100%;
height: 100%;
background-color: rgba(255, 255, 255, 0.8);
position: absolute;
top: 0;
left: 0;
cursor: pointer;
}
3. 刮刮乐功能
使用JavaScript来实现刮刮乐的刮除效果。监听鼠标事件并在划过的地方显示透明区域。
javascript
// script.js
const scratchArea = document.querySelector('.scratch-area');
scratchArea.addEventListener('mousemove', (e) => {
if (e.buttons !== 1) return; // 仅在按下鼠标时触发
const x = e.offsetX;
const y = e.offsetY;
const circle = document.createElement('div');
circle.style.width = '20px';
circle.style.height = '20px';
circle.style.borderRadius = '50%';
circle.style.position = 'absolute';
circle.style.left = `${x - 10}px`;
circle.style.top = `${y - 10}px`;
circle.style.backgroundColor = 'rgba(255, 255, 255, 0)'; //透明区域
scratchArea.appendChild(circle);
});
// 添加清除功能
scratchArea.addEventListener('mouseleave', () => {
scratchArea.style.pointerEvents = 'none'; // 禁用鼠标事件
});
4. 整体效果
上述代码将创建一个简单的刮刮乐奖券布局。用户可以使用鼠标在刮刮乐区域上"刮"出隐藏的信息,展现出奖品内容。
通过这种方式,我们可以轻松地创建一个交互式的刮刮乐奖券,结合HTML5、CSS和JavaScript技术,提供一个有趣的用户体验。
相关推荐
ohMyGod_12339 分钟前
用React实现一个秒杀倒计时组件eternal__day42 分钟前
第三期:深入理解 Spring Web MVC [特殊字符](数据传参+ 特殊字符处理 + 编码问题解析)醋醋1 小时前
Vue2源码记录艾克马斯奎普特1 小时前
Vue.js 3 渐进式实现之响应式系统——第四节:封装 track 和 trigger 函数江耳1 小时前
从10秒到无限流:我用Vercel+NextJS实现AI流式对话遇到的超时问题及解决方案总之就是非常可爱1 小时前
三分钟让你看懂alien-signals computed基本原理JustHappy1 小时前
「我们一起做组件库🌻」虚拟消息队列?message组件有何不同?(VersakitUI开发实录)Carlos_sam1 小时前
Openlayers:为Overlay创建element的四种方式纵昂1 小时前
Js中常用数据转换及方法记录汇总还是鼠鼠1 小时前
Node.js中间件的5个注意事项热门推荐
01我决定放弃搞 Java 了02DeepSeek各版本说明与优缺点分析03如何在WPS和Word/Excel中直接使用DeepSeek功能04汽车上的各种质量:整备质量、总质量、装载质量、簧上质量、簧下质量05RAG 实践- Ollama+RagFlow 部署本地知识库06从零安装 LLaMA-Factory 微调 Qwen 大模型成功及所有的坑07唐刘:关于产品质量的思考 - 如何评估质量08本地化部署AI知识库:基于Ollama+DeepSeek+AnythingLLM保姆级教程09DeepSeek RAGFlow构建本地知识库系统10SpringAI整合Ollama集成DeepSeek