使用html5写一个刮刮乐奖券的布局

"```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技术,提供一个有趣的用户体验。

" 复制代码
相关推荐
广州华水科技18 小时前
单北斗GNSS变形监测在地质灾害与基础设施安全中的应用与优势分析
前端
程序员鱼皮18 小时前
又被 Cursor 烧了 1 万块,我麻了。。。
前端·后端·ai·程序员·大模型·编程
孟祥_成都18 小时前
nextjs 16 基础完全指南!(一) - 初步安装
前端·next.js
程序员爱钓鱼18 小时前
使用简单 JSON + 自定义 t 函数实现轻量多语言国际化(无需 next-intl)
前端·javascript·trae
一 乐19 小时前
助农平台|基于SprinBoot+vue的助农服务系统(源码+数据库+文档)
前端·javascript·数据库·vue.js·ecmascript·springboot
vivo互联网技术19 小时前
浅谈 AI 搜索前端打字机效果的实现方案演进
前端·vue·dom
●VON19 小时前
Electron 小游戏实战:太空打砖块(Space Breakout)
前端·javascript·electron
新晨43719 小时前
Vue 3 定时器清理的最佳实践
javascript·vue.js
重铸码农荣光19 小时前
深入理解 JavaScript 原型机制:从“如何拿到小米 SU7”说起
前端·javascript
Zyx200719 小时前
深入 JavaScript 事件机制:从冒泡到事件委托的高效实践
javascript