wed前端第三次作业

一:使用js完成抽奖项目 效果和内容自定义,可以模仿游戏抽奖页面

1、相关代码

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>抽奖活动</title>
  <style>
    * {
      margin: 0;
      padding: 0;
    }
    h2 {
      text-align: center;
    }
    .box {
      width: 600px;
      margin: 50px auto;
      display: flex;
      font-size: 25px;
      line-height: 40px;
    }
    .qs {
      width: 450px;
      height: 40px;
      color: red;
 
    }
    .btns {
      text-align: center;
    }
    .btns button {
      width: 120px;
      height: 35px;
      margin: 0 50px;
    }
    .selected {
      width: 600px;
      margin: 50px auto;
      display: flex;
      font-size: 25px;
      line-height: 40px;
    }
    .list {
      color: red;
    }
  </style>
</head>
<body>
    <h2>随机抽奖</h2>
    <div class="box">
        <span>当前奖品:</span>
        <div class="qs">点击开始抽奖</div>
    </div>
    <div class="btns">
        <button class="start">开始</button>
        <button class="end">结束</button>
    </div>
        <div class="selected">
        <span>已获奖品:</span>
        <div class="list"></div>
    </div>
    <script>
        // 奖品池 
        const prizes = [
            'iPhone 15 Pro',
            'Switch 游戏机',
            '小米平板 6',
            '100 元话费',
            '蓝牙耳机',
            '腾讯视频年卡',
            '机械键盘',
            '充电宝',
            '抱枕',
            '谢谢参与',
            '再来一次'
        ];
        let timerId = 0;
        let random    = 0;
        const qs      = document.querySelector('.qs');
        const listBox = document.querySelector('.list');
        const start   = document.querySelector('.start');
        const end     = document.querySelector('.end');
        start.addEventListener('click', () => {
            if (prizes.length <= 1) {
                start.disabled = end.disabled = true;
                return;
            }
            timerId = setInterval(() => {
                random = Math.floor(Math.random() * prizes.length);
                qs.textContent = prizes[random];
            }, 100);
        });
        end.addEventListener('click', () => {
            clearInterval(timerId);
            const prize = prizes.splice(random, 1)[0]; 
            showPrize(prize);
        });
        function showPrize(prize) {
            const div = document.createElement('div');
            div.textContent = prize;
            listBox.appendChild(div);
        }
    </script>
</body>
</html>

2、运行结果

可以连续抽奖十次

相关推荐
tedcloud1238 小时前
UI-TARS-desktop部署教程:构建AI桌面自动化系统
服务器·前端·人工智能·ui·自动化·github
UXbot11 小时前
AI原型设计工具如何支持团队协作与快速迭代
前端·交互·个人开发·ai编程·原型模式
ZC跨境爬虫12 小时前
跟着MDN学HTML_day_48:(Node接口)
前端·javascript·ui·html·音视频
PieroPc13 小时前
CAMWATCH — 局域网摄像头监控系统 Fastapi + html
前端·python·html·fastapi·监控
巴巴博一14 小时前
2026 最新:Trae / Cursor 一键接入 taste-skill 完整教程(让 AI 前端告别“AI 味”)
前端·ai·ai编程
kyriewen14 小时前
半夜三点线上崩了,AI替我背了锅——用AI排错,五分钟定位三年老bug
前端·javascript·ai编程
kyriewen15 小时前
我让 AI 当了 24 小时全年无休的“毒舌考官”
前端·ci/cd·ai编程
hexu_blog15 小时前
vue+java实现图片批量压缩
java·前端·vue.js
IT_陈寒15 小时前
为什么你应该学习JavaScript?
前端·人工智能·后端
lifejump15 小时前
Empire(帝国)CMS 7.5 XSS注入
前端·安全·xss