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

本文主要是介绍前端三件套 | 综合练习:模拟抽奖活动,实现一个简单的随机抽取并显示三名获胜者,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

随机运行结果如下:


参考代码如下:

<!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 2const 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.chinasem.cn/article/811348

相关文章

python使用watchdog实现文件资源监控

《python使用watchdog实现文件资源监控》watchdog支持跨平台文件资源监控,可以检测指定文件夹下文件及文件夹变动,下面我们来看看Python如何使用watchdog实现文件资源监控吧... python文件监控库watchdogs简介随着Python在各种应用领域中的广泛使用,其生态环境也

el-select下拉选择缓存的实现

《el-select下拉选择缓存的实现》本文主要介绍了在使用el-select实现下拉选择缓存时遇到的问题及解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录项目场景:问题描述解决方案:项目场景:从左侧列表中选取字段填入右侧下拉多选框,用户可以对右侧

基于Qt开发一个简单的OFD阅读器

《基于Qt开发一个简单的OFD阅读器》这篇文章主要为大家详细介绍了如何使用Qt框架开发一个功能强大且性能优异的OFD阅读器,文中的示例代码讲解详细,有需要的小伙伴可以参考一下... 目录摘要引言一、OFD文件格式解析二、文档结构解析三、页面渲染四、用户交互五、性能优化六、示例代码七、未来发展方向八、结论摘要

Python pyinstaller实现图形化打包工具

《Pythonpyinstaller实现图形化打包工具》:本文主要介绍一个使用PythonPYQT5制作的关于pyinstaller打包工具,代替传统的cmd黑窗口模式打包页面,实现更快捷方便的... 目录1.简介2.运行效果3.相关源码1.简介一个使用python PYQT5制作的关于pyinstall

使用Python实现大文件切片上传及断点续传的方法

《使用Python实现大文件切片上传及断点续传的方法》本文介绍了使用Python实现大文件切片上传及断点续传的方法,包括功能模块划分(获取上传文件接口状态、临时文件夹状态信息、切片上传、切片合并)、整... 目录概要整体架构流程技术细节获取上传文件状态接口获取临时文件夹状态信息接口切片上传功能文件合并功能小

python实现自动登录12306自动抢票功能

《python实现自动登录12306自动抢票功能》随着互联网技术的发展,越来越多的人选择通过网络平台购票,特别是在中国,12306作为官方火车票预订平台,承担了巨大的访问量,对于热门线路或者节假日出行... 目录一、遇到的问题?二、改进三、进阶–展望总结一、遇到的问题?1.url-正确的表头:就是首先ur

C#实现文件读写到SQLite数据库

《C#实现文件读写到SQLite数据库》这篇文章主要为大家详细介绍了使用C#将文件读写到SQLite数据库的几种方法,文中的示例代码讲解详细,感兴趣的小伙伴可以参考一下... 目录1. 使用 BLOB 存储文件2. 存储文件路径3. 分块存储文件《文件读写到SQLite数据库China编程的方法》博客中,介绍了文

Redis主从复制实现原理分析

《Redis主从复制实现原理分析》Redis主从复制通过Sync和CommandPropagate阶段实现数据同步,2.8版本后引入Psync指令,根据复制偏移量进行全量或部分同步,优化了数据传输效率... 目录Redis主DodMIK从复制实现原理实现原理Psync: 2.8版本后总结Redis主从复制实

JAVA利用顺序表实现“杨辉三角”的思路及代码示例

《JAVA利用顺序表实现“杨辉三角”的思路及代码示例》杨辉三角形是中国古代数学的杰出研究成果之一,是我国北宋数学家贾宪于1050年首先发现并使用的,:本文主要介绍JAVA利用顺序表实现杨辉三角的思... 目录一:“杨辉三角”题目链接二:题解代码:三:题解思路:总结一:“杨辉三角”题目链接题目链接:点击这里

基于Python实现PDF动画翻页效果的阅读器

《基于Python实现PDF动画翻页效果的阅读器》在这篇博客中,我们将深入分析一个基于wxPython实现的PDF阅读器程序,该程序支持加载PDF文件并显示页面内容,同时支持页面切换动画效果,文中有详... 目录全部代码代码结构初始化 UI 界面加载 PDF 文件显示 PDF 页面页面切换动画运行效果总结主