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

" 复制代码
相关推荐
kite01213 小时前
浏览器工作原理06 [#]渲染流程(下):HTML、CSS和JavaScript是如何变成页面的
javascript·css·html
крон3 小时前
【Auto.js例程】华为备忘录导出到其他手机
开发语言·javascript·智能手机
coding随想5 小时前
JavaScript ES6 解构:优雅提取数据的艺术
前端·javascript·es6
年老体衰按不动键盘5 小时前
快速部署和启动Vue3项目
java·javascript·vue
小小小小宇5 小时前
一个小小的柯里化函数
前端
灵感__idea5 小时前
JavaScript高级程序设计(第5版):无处不在的集合
前端·javascript·程序员
小小小小宇5 小时前
前端双Token机制无感刷新
前端
小小小小宇5 小时前
重提React闭包陷阱
前端
小小小小宇5 小时前
前端XSS和CSRF以及CSP
前端
UFIT5 小时前
NoSQL之redis哨兵
java·前端·算法