前端三件套 | 综合练习:模拟抽奖活动,实现一个简单的随机抽取并显示三名获胜者

news2025/1/12 0:58:03

随机运行结果如下:


参考代码如下:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        .box {
            margin: 0 auto;
            width: 840px;
            height: 615px;
            background: url(./pic_jiangzhuang.png) no-repeat center / cover;
            padding: 100px 250px;
            block-size: border-box;
            /* 设置为怪异盒:设定的宽高是整个盒子的大小 内边距这些会压缩内容大小 */
            /* 使得里面的内容显示在背景图中央 */
            display: flex;
            /* 使用flex布局 */
            flex-wrap: wrap;
            justify-content: center;
            /* 水平居中 */
            align-items: center;
            /* 垂直居中 */
            box-sizing: border-box;
            /* 确保宽度和高度包括内边距和边框  */
            position: relative;
            /* 父相子绝 实现内容定位放置 */

        }

        .box b {
            display: inline-block;
            position: absolute;
            top: 10rem;
            left: 19rem;
        }

        .box h1 {
            position: absolute;
            top: 16rem;
        }

        .box h3 {
            position: absolute;
            top: 20rem;
        }

        .box h5 {
            position: absolute;
            top: 23rem;
        }
    </style>
</head>

<body>
    <div class="box">
        <b>305最佳美女决赛 让我们拭目以待</b>
        <h1>第一名:
            <span class="one">???</span>
        </h1>
        <h3>第二名:
            <span class="two">???</span>
        </h3>
        <h5>第三名:
            <span class="three">???</span>
        </h5>
    </div>
    <script>
        // 1.声明数组 用于后续随机抽取 名字下标对应 0 1 2
        const personArr = ['ZM', 'WZY', 'LMF']
        // 2.先抽一等奖 抽完一个删一个 避免重复
        // 2.1得到随机数 random是一个得到的随机数组下标
        const random1 = Math.floor(Math.random() * personArr.length)
        // 2.2 获取one元素
        const one = document.querySelector('.one')
        // 2.3 修改这个元素的值 personArr[random]为数组里的某个属性
        one.innerHTML = personArr[random1]
        // 2.4 抽出一个 删一个 避免重复
        personArr.splice(random1, 1)// 数组的删除

        // 3.抽二等奖
        // 3.1得到随机数 random1是一个得到的随机数组下标
        const random2 = Math.floor(Math.random() * personArr.length)
        // 3.2 获取two元素
        const two = document.querySelector('.two')
        // 3.3 修改这个元素的值 personArr[random]为数组里的某个属性
        two.innerHTML = personArr[random2]
        // 3.4 抽出一个 删一个 避免重复
        personArr.splice(random2, 1)// 数组的删除

        // 4.抽三等奖
        // 4.1得到随机数 random1是一个得到的随机数组下标
        const random3 = Math.floor(Math.random() * personArr.length)
        // 4.2 获取three元素
        const three = document.querySelector('.three')
        // 4.3 修改这个元素的值 personArr[random]为数组里的某个属性
        three.innerHTML = personArr[random3]
        // 4.4 抽出一个 删一个 避免重复
        personArr.splice(random3, 1)// 数组的删除


    </script>
</body>

</html>

考察知识点如下:

HTML标签和元素:

1.使用<div>、<b>、<h1>、<h3>、<h5>等HTML标签来构建页面结构。

CSS样式:

1.background属性用于设置背景图片。

2.display: flex;用于创建弹性布局容器。

3.justify-content和align-items用于水平和垂直居中容器内的元素。

4.position: absolute;用于绝对定位元素。

5.box-sizing: border-box;确保元素的宽度和高度包括内边距和边框。

JavaScript基础:

1.Math.random()用于生成随机数。

2.Math.floor()用于向下取整。

3.querySelector()用于选择页面上的元素。

4.innerHTML用于获取或设置元素的HTML内容。

5.splice()用于从数组中删除元素。

DOM操作:

1.通过JavaScript来修改HTML元素的内容。

理解这段代码的关键在于理解以下几个方面:

❤:personArr数组存储了所有可能的获奖者姓名。初始化时,这个数组包含三个名字。

❤:Math.random()生成一个0到1之间的随机小数,Math.floor()将这个小数向下取整为整数

❤:personArr.length将这个整数乘以数组长度,得到一个0到数组长度减1之间的随机整数。

❤:document.querySelector()方法用于选择具有指定选择器的第一个元素。在这里,它分别用于选择.one、.two和.three类的span元素。

❤:personArr.splice(index, count)方法用于从数组中删除指定索引处的count个元素,并返回被删除的元素数组。这样可以确保每个获奖者只被选中一次,并且在被选中后从候选名单中移除。

❤:最后,更新span元素的innerHTML属性,将其设置为对应的获奖者姓名,从而在网页上显示最终结果。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1524292.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

分数相加减(C语言)

一、流程图&#xff1b; 二、源代码&#xff1b; # define _CRT_SECURE_NO_WARNINGS # include <stdio.h>int main() {//初始化变量值&#xff1b;int fenmu 2;int result 1;int fuhao 1;//执行循环&#xff1b;while (fenmu < 100){//运算&#xff1b;fuhao (-1…

深度学习1650ti在win10安装pytorch复盘

深度学习1650ti在win10安装pytorch复盘 前言1. 安装anaconda2. 检查更新显卡驱动3. 根据pytorch选择CUDA版本4. 安装CUDA5. 安装cuDNN6. conda安装pytorch结语 前言 建议有条件的&#xff0c;可以在安装过程中&#xff0c;开启梯子。例如cuDNN安装时登录 or 注册&#xff0c;会…

Redis应用与原理(一)

更好的阅读体验 \huge{\color{red}{更好的阅读体验}} 更好的阅读体验 缓存发展史 缓存经典场景 在没有引入缓存前&#xff0c;为了应对大量流量&#xff0c;一般采用&#xff1a; LVS 代理Nginx 做负载均衡搭建 Tomcat 集群 这种方式下&#xff0c;随着访问量的增大&#xf…

Python 蜂窝六边形分析

在本文中,我们将使用 Wildland Fire Interagency Geospatial Services (WFIGS) 2022 数据集,并仅关注新墨西哥州的 Hermits Peak / Calf Canyon 火灾。这场野火是该州历史上规模最大的野火,烧毁面积超过 30 万英亩。大火位于陶斯和圣达菲之间,烧毁了桑格雷德克里斯托山脉的…

继承 ResponseEntityExceptionHandler

目录 作用概述 示例-HttpRequestMethodNotSupportedException 示例-自定义异常处理 总示例 使用了ResponseEntityExceptionHandler后&#xff0c;为什么发生了异常后返回体为空 方法执行顺序 作用概述 这是一个方便的基类&#xff0c;用于希望通过 ExceptionHandler 方法…

centos7修改ssh登录错误限制和端口修改

前几天登录服务器的时候发现有错误登录信息15w多条&#xff0c;该服务器映射了外网&#xff0c;估计是被爆破了。为了防止再有人进行爆破&#xff0c;修改一下ssh的限制登录顺便把默认端口改掉 编辑ssh配置文件 vim /etc/ssh/sshd_config去掉注释 按需修改次数 MaxAuthTries 6…

云服务器2核4G5M配置代表什么意思?

腾讯云服务器2核4G5M带宽配置是代表什么&#xff1f;代表2核CPU、4G内存、5M公网带宽&#xff0c;这是一款轻量应用服务器&#xff0c;系统盘为60GB SSD云硬盘&#xff0c;活动页面 txybk.com/go/txy 活动打开如下图&#xff1a; 腾讯云2核4G5M服务器 如上图所示&#xff0c;这…

EDA事件驱动架构/BASE理论/幂等性理论

EDA事件驱动架构&#xff1a;Event Driven Architecture 消息组件&#xff1a;不仅仅是削峰填谷 而且可以做事件驱动架构 EDA驱动的特定&#xff1a;异步处理、跨平台/语言通信、应用解耦、可靠投递、最终一致性 BASE理论&#xff1a; 基本可用 Basically Available 软状态 …

JavaScript做一个贪吃蛇小游戏,无需网络直接玩。

用JavaScript做一个贪吃蛇小游戏&#xff0c;无需网络 > 打开即可玩。 html代码&#xff1a; <!DOCTYPE html> <html lang"zh"> <head><meta charset"UTF-8"><title>Title</title><style>#game{width: 344p…

json-server库的使用,实现数据模拟

项目目录 安装 npm i -g json-server0.17.4 启动单个json服务&#xff0c;在cookbook目录下执行命令&#xff1a; json-server ./mock/a.json -p 9000 待实现 使用0.17.4版本即可。

BIG-Bench Hard 数据集分享

来源: AINLPer公众号&#xff08;每日干货分享&#xff01;&#xff01;&#xff09; 编辑: ShuYini 校稿: ShuYini 时间: 2024-3-17 该数据集由Google、斯坦福等研究人员开发&#xff0c;BBH的全称是BIG-Bench Hard&#xff0c;它是BIG-Bench数据集的一个子集&#xff0c;它专…

前端工程化(二)(精品、面试必备基础)(春招、秋招)

目录 什么是模块化?CommonJS规范和Node关系模块化的核心exports 导出 & require 导入模块加载(持续更新) 什么是模块化? 事实上模块化开发最终的目的是将程序划分成一个个小的结构&#xff1b; 这个结构中编写属于自己的逻辑代码&#xff0c;有自己的作用域&#xff0c;…

代码随想录(day6)——哈希表

Leetcode.242 有效的字母异位词&#xff1a; 242. 有效的字母异位词 - 力扣&#xff08;LeetCode&#xff09; 原理简单&#xff0c;首先判断给定的两个字符串的长度是否相等&#xff0c;如果不相等则直接返回&#xff0c;只有在给定字符串长度想的的情况下才进行下一步的判断…

(三)OpenOFDM符号对齐

符号对齐 模块&#xff1a;sync_long.v输入&#xff1a;I (16), Q (16), phase_offset (32), short_gi (1)输出&#xff1a;long_preamble_detected (1), fft_re (16), fft_im (16) 检测到数据包后&#xff0c;下一步是精确确定每个 OFDM 符号的起始位置。在802.11中&#xf…

4-如何进行细分市场分析-03 竞争者分析

任何一个行业肯定都是有很多竞争者&#xff0c;我们如何判断这些竞争者对我们有什么样的威胁、什么样的机会、什么样的影响&#xff0c;我们需要去分析这些竞争者。 行业竞争格局如何分析&#xff1f; 我们可以从一些基本指标来入手&#xff0c;如市场集中度、行业利润率。 竞…

(学习日记)2024.03.15:UCOSIII第十七节:任务的挂起和恢复

写在前面&#xff1a; 由于时间的不足与学习的碎片化&#xff0c;写博客变得有些奢侈。 但是对于记录学习&#xff08;忘了以后能快速复习&#xff09;的渴望一天天变得强烈。 既然如此 不如以天为单位&#xff0c;以时间为顺序&#xff0c;仅仅将博客当做一个知识学习的目录&a…

ChatGPT提示词方法的原理

关于提示词&#xff0c;我之前的一些文章可以参考&#xff1a; 【AIGC】AI作图最全提示词prompt集合&#xff08;收藏级&#xff09;https://giszz.blog.csdn.net/article/details/134815245?ydrefereraHR0cHM6Ly9tcC5jc2RuLm5ldC9tcF9ibG9nL21hbmFnZS9hcnRpY2xlP3NwbT0xMDExL…

SAR ADC教程系列5——FFT频谱泄露以及相干采样

频谱泄露的出现以及如何规避&#xff1f; 为什么要相干采样&#xff1f; 1.分析ADC输出信号的频谱工具&#xff1a;DFT&#xff08;Discrete Fourier Transform) 重点&#xff1a;DFT相邻频谱频率间隔为fs/N 如何规避频谱泄露&#xff1f; 对于DFT&#xff0c;它对于接收到的信…

2024 年(第 12 届)“泰迪杯”数据挖掘挑战赛——A 题:生产线的故障自动识别与人员配置具体思路以及源代码分析

一、问题背景 随着新兴信息技术的大规模应用&#xff0c;工业生产线的智能化控制技术日益成熟。自动生产线 可以自动完成物品传送、物料填装、产品包装和质量检测等过程&#xff0c;极大地提高了生产效率和 产品质量&#xff0c;减少了生产成本。自动生产线融入故障智能报警…

学习笔记--强化学习(1)

参考&#xff1a;https://blog.csdn.net/koulongxin123/article/details/122676149 1.什么是强化学习&#xff1f; (1)定义 基于环境的反馈而行动&#xff0c;通过不断与环境的交互、试错&#xff0c;最终完成特定目的或者使得整体行动收益最大化&#xff08;是一种通过与环境…