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

" 复制代码
相关推荐
小码哥_常几秒前
Android新航标:Navigation 3为何成为变革先锋?
前端
SuperEugene1 分钟前
Vue状态管理扫盲篇:状态管理中的常见坑 | 循环依赖、状态污染与调试技巧
前端·vue.js·面试
骑着小黑马2 分钟前
从 Electron 到 Tauri 2:我用 3.5MB 做了个音乐播放器
前端·vue.js·typescript
进击的尘埃3 分钟前
前端大文件上传全方案:切片、秒传、断点续传与 Worker 并行 Hash 计算实践
javascript
aykon3 分钟前
DataSource详解以及优势
前端
Mintopia3 分钟前
戴了 30 天智能手环后,我才发现自己一直低估了“睡眠”
前端
leolee183 分钟前
react redux 简单使用
前端·react.js·redux
仰望星空的小猴子4 分钟前
常用的Hooks
前端
天才熊猫君4 分钟前
Vue Fragment 锚点机制
前端
米丘5 分钟前
Git 常用操作命令
前端