当前位置: 首页 > article >正文

js考核第三题

题三:随机点名

要求: 分为上下两个部分,上方为显示区域,下方为控制区域。显示区域显示五十位群成员的学号和姓名,控制区域由开始和结束两个按钮 组成。点击开始按钮,显示区域里的内容开始滚动,点击结束按钮,内容滚动停止,随机显示一位成员的学号和姓名。

html 部分

<body>
    <div class="display">
        <ul class="list"></ul>
    </div>
    <div class="anliu">
        <button class="start">开始</button>
        <button class="stop">结束</button>
    </div>

css部分

<style>
        body {
            margin: 0;
            padding: 0;
            display: flex;
            flex-direction: column;
            height: 100vh;
        }

        .display {
            flex: 1;
            overflow: hidden;
            background-color: #f0f0f0;
            padding: 20px;
            box-sizing: border-box;
            position: relative;
        }
        @keyframes scroll {
            0% {
                top: 0;
            }
            100% {
                top: -100%;
            }
        }
        .list {
            list-style: none;
            margin: 0;
            padding: 0;
            position: absolute;
            top: 0;
            width: 100%;
        }

        .list li {
            padding: 10px;
            font-size: 18px;
            border-bottom: 1px solid #ccc;
        }
        .anliu {
            display: flex;
            justify-content: center;
            gap: 20px;
            padding: 20px;
            background-color: #ddd;
        }

        button {
            padding: 10px 20px;
            font-size: 16px;
            cursor: pointer;/*变成小手*/
            border: none;
            background-color: green;
            color: white;
            border-radius: 5px;
        }

        button:hover {
            background-color: red;
        }
    </style>

js部分

<script>
        document.addEventListener('DOMContentLoaded', function () {
            const list = document.querySelector('.list');
            const start = document.querySelector('.start');
            const stop = document.querySelector('.stop');

            const yb = [
                { id: '23120901', name: '姜怡雯' },
                { id: '23210204', name: '付煜舒' },
                { id: '23210210', name: '岳含旭' },
                { id: '23210310', name: '赵可' },
                { id: '23210406', name: '施紫涵' },
                { id: '23210408', name: '郑欣妍' },
                { id: '23210605', name: '李晶靓' },
                { id: '23210606', name: '马诗雨' },
                { id: '23210610', name: '杨嘉润' },
                { id: '23220125', name: '薛睿' },
                { id: '23220204', name: '陆萧彦' },
                { id: '23220418', name: '李华勇' },
                { id: '23220422', name: '王翰铭' },
                { id: '23220426', name: '徐新洪' },
                { id: '23220506', name: '张盼' },
                { id: '23220607', name: '张婉玉' },
                { id: '23220623', name: '王学潮' },
                { id: '23220705', name: '石一汝' },
                { id: '23220714', name: '高俊宇' },
                { id: '23230101', name: '陈思静' },
                { id: '23230102', name: '高紫怡' },
                { id: '23230103', name: '李嘉慧' },
                { id: '23230104', name: '李思怡' },
                { id: '23230205', name: '唐艺文' },
                { id: '23240101', name: '季雅雯' },
                { id: '23240207', name: '吕倩雨' },
                { id: '23240301', name: '周婉愉' },
                { id: '23240412', name: '郑伯熙' },
                { id: '23240426', name: '孙致远' },
                { id: '23250316', name: '顾成志' },
                { id: '23250411', name: '朱逸倩' },
                { id: '23320515', name: '崔齐鑫' },
                { id: '24110319', name: '范熠阳' },
                { id: '24121002', name: '钱姝澄' },
                { id: '24121309', name: '向文杰' },
                { id: '24210110', name: '任焯琳' },
                { id: '24210119', name: '卜家文' },
                { id: '24210214', name: '许成晨' },
                { id: '24210319', name: '钱岩' },
                { id: '24210414', name: '刘志豪' },
                { id: '24210512', name: '郑鸿强' },
                { id: '24210609', name: '倪张睿' },
                { id: '24210702', name: '冯雅琳' },
                { id: '24210704', name: '李晓熙' },
                { id: '24210716', name: '魏冕' },
                { id: '242108111', name: '盛健翔' },
                { id: '24210822', name: '周锦浩' }
            ];

            function showMembers() {
                let htmlContent = '';
                for (let i = 0; i < yb.length; i++) {
                    const currentYb = yb[i];
                    htmlContent += `<li>学号:${currentYb.id},姓名:${currentYb.name}</li>`;
                }
                list.innerHTML = htmlContent;
            }

            function startScroll() {
                list.style.animation = 'scroll 1s linear infinite'; 
            }

            function stopScroll() {
                list.style.animation = 'none';
                const randomIndex = Math.floor(Math.random() * yb.length);
                const randomYb = yb[randomIndex];
                list.innerHTML = `<li>学号:${randomYb.id},姓名:${randomYb.name}</li>`;
            }

            start.addEventListener('click', startScroll);
            stop.addEventListener('click', stopScroll);

            showMembers();
        });
    </script>

视频:

js第三题


http://www.kler.cn/a/547581.html

相关文章:

  • 20250214 随笔 Elasticsearch(ES)索引数据 vs. 业务数据库冗余双写
  • 智能AI之隐私安全,尤其是医疗
  • Python - 构造函数、继承与重载
  • firefox的升级
  • 【PyQt】PyQt复选框与单选框
  • 【Linux网络编程】应用层协议HTTP(请求方法,状态码,重定向,cookie,session)
  • 类与对象C++详解(中)-----构造函数与析构函数
  • Unity CommandBuffer绘制粒子系统网格显示
  • 《Mycat核心技术》第14章:实现ER分片
  • VSCode配合cline实现自动编程
  • 5分钟掌握LM Studio本地部署DeepSeek R1
  • Spark 性能优化(四):Cache
  • 2025 (ISC)²CCSP 回忆录
  • 简述 tsconfig.json 中 rootDir 和 include 之间的关系
  • 设计模式——职责链模式
  • 【原理图与PCB专题】如果想要建立标准原理图有哪些思路?
  • ClickHouse的前世今生
  • 【ISO 14229-1:2023 UDS诊断全量测试用例清单系列:第十九节】
  • 集成测试总结文档
  • Node.js简介及vue项目与Node.js通信方法