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

" 复制代码
相关推荐
excel2 小时前
为什么在 Three.js 中平面能产生“起伏效果”?
前端
excel3 小时前
Node.js 断言与测试框架示例对比
前端
天蓝色的鱼鱼4 小时前
前端开发者的组件设计之痛:为什么我的组件总是难以维护?
前端·react.js
codingandsleeping4 小时前
使用orval自动拉取swagger文档并生成ts接口
前端·javascript
石金龙5 小时前
[译] Composition in CSS
前端·css
白水清风5 小时前
微前端学习记录(qiankun、wujie、micro-app)
前端·javascript·前端工程化
Ticnix6 小时前
函数封装实现Echarts多表渲染/叠加渲染
前端·echarts
用户22152044278006 小时前
new、原型和原型链浅析
前端·javascript
阿星做前端6 小时前
coze源码解读: space develop 页面
前端·javascript
叫我小窝吧6 小时前
Promise 的使用
前端·javascript