Web前端开发 小实训(一) 成绩分类统计

news2024/11/18 23:41:36

用于学生web前端开发课程实训练习,掌握基本语法和数据类型

实训目的

使用分支语句,完成分数统计与等级对比,通过输入框输入分数,可以根据分数多少划分等级。

参考思路:

分析题目:根据输入分数进行等级划分。

操作过程

第一步:获取输入弹出的分数:

 let score = prompt("请输入成绩");

第二步:判断输入的内容是否符合要求:

  if(isNaN(score) || !Number.isInteger(Number(score)) || score<0){
        alert("输入的数据有误,请重新加载!");     
}

第三步:根据分数进行等级判断

 if(isNaN(score) || score > 100 || score < 0){
                alert("输入成绩有误,结束输入!");
 }else if(score >= 90){
                alert("该同学的成绩是A!");
                        }else if(score >=80){
                alert("该同学的成绩是B!");
                        }else if(score >=70){
                alert("该同学的成绩是C!");
                        }else if(score >= 60){
                alert("该同学的成绩是D!");
                           }else{
                alert("该同学的成绩是E!");
                }

实战升级1

1、弹窗提示用户要输入Web程序设计成绩的学生人数,并对每个学生的成绩进行打分,打分后立即弹窗告知分数对应的等级

思路:

对当前代码新增需求:针对多个同学进行分数统计,获取有几个同学要登录成绩,进行输出:

第一步:获取学生数量,并判断数据是否正确:

 let student_number = prompt("请输入需要分数统计的同学数量:");
        //判断:判断数据是否正常
        if (isNaN(student_number) || !Number.isInteger(Number(student_number)) || student_number < 1) {
            alert("同学数量有误!");
        } else {
......//要更新的内容
}

第二步:根据学生数量,循环获取每一位同学的分数并展示。

 ....else {
            for (let index = 1; index <= student_number; index++) {
                let score = prompt("请输入第"+index+"个同学的成绩");//修改此处代码
                if (isNaN(score) || !Number.isInteger(Number(score))) {
                    alert("输入的数据有误,请重新加载!");
                }
                if (isNaN(score) || score > 100 || score < 0) {
                    alert("输入成绩有误,结束输入!");
                } else if (score >= 90) {
                    alert("该同学的成绩是A!");
                } else if (score >= 80) {
                    alert("该同学的成绩是B!");
                } else if (score >= 70) {
                    alert("该同学的成绩是C!");
                } else if (score >= 60) {
                    alert("该同学的成绩是D!");
                } else {
                    alert("该同学的成绩是E!");
                }
            }
            }

实战升级2

在输入完所有同学的成绩后,通过程序分析出获得每个获得等级的人数是多少,并展示在页面中。

对当前代码新增需求:将每个同学的等级进行归纳统计,可以在页面将等级的学生数量进行展示:

第一步:设置五个成绩分段的变量

  let rank_a_count = 0;
  let rank_b_count = 0;
  let rank_c_count = 0;
  let rank_d_count = 0;
  let rank_e_count = 0;

第二步:针对每一个分数区间的同学等级数量让上述变量进行自增。

...
} else if (score >= 90) {
                    alert("该同学的成绩是A!");
                    rank_a_count++;
                } else if (score >= 80) {
                    alert("该同学的成绩是B!");
                    rank_b_count++;
                } else if (score >= 70) {
                    alert("该同学的成绩是C!");
                    rank_c_count++;
                } else if (score >= 60) {
                    alert("该同学的成绩是D!");
                    rank_d_count++;
                } else {
                    alert("该同学的成绩是E!");
                    rank_e_count++;
                }

第三步:把等级数量的统计展示

 //展示:
    document.write("本次共计"+student_number+"位同学录入成绩等级分布如下:<br>");
    document.write("获得等级A的同学人数:"+rank_a_count+"<br>");
    document.write("获得等级B的同学人数:"+rank_b_count+"<br>");
    document.write("获得等级C的同学人数:"+rank_c_count+"<br>");
    document.write("获得等级D的同学人数:"+rank_d_count+"<br>");
document.write("获得等级E的同学人数:"+rank_e_count+"<br>");

补充:如果出现数据错误,请立即提示。

 if (isNaN(score) || !Number.isInteger(Number(score))) {   Number();//其他类型转数字类型, Number.isInteger()判断是否为整数
                    alert("输入的数据有误,请重新加载!");
  }

完整代码

    <script>
        let rank_a_count = 0;
        let rank_b_count = 0;
        let rank_c_count = 0;
        let rank_d_count = 0;
        let rank_e_count = 0;
        let student_number = prompt("请输入需要分数统计的同学数量:");
        //判断:判断数据是否正常
        if (isNaN(student_number) || !Number.isInteger(Number(student_number)) || student_number < 1) {
            alert("同学数量有误!");
        } else {
            for (let index = 1; index <= student_number; index++) {
                let score = prompt("请输入第" + index + "个同学的成绩");
                if (isNaN(score) || !Number.isInteger(Number(score))) {
                    alert("输入的数据有误,请重新加载!");
                } else if (score > 100 || score < 0) {
                    alert("输入成绩有误,该同学没有成绩");
                } else if (score >= 90) {
                    alert("该同学的成绩是A!");
                    rank_a_count++;
                } else if (score >= 80) {
                    alert("该同学的成绩是B!");
                    rank_b_count++;
                } else if (score >= 70) {
                    alert("该同学的成绩是C!");
                    rank_c_count++;
                } else if (score >= 60) {
                    alert("该同学的成绩是D!");
                    rank_d_count++;
                } else {
                    alert("该同学的成绩是E!");
                    rank_e_count++;
                }
            }
        }
    //展示:
    document.write("本次共计"+student_number+"位同学录入成绩等级分布如下:<br>");
    document.write("获得等级A的同学人数:"+rank_a_count+"<br>");
    document.write("获得等级B的同学人数:"+rank_b_count+"<br>");
    document.write("获得等级C的同学人数:"+rank_c_count+"<br>");
    document.write("获得等级D的同学人数:"+rank_d_count+"<br>");
    document.write("获得等级E的同学人数:"+rank_e_count+"<br>");
    </script>

因面向的是初学Web前端课程的学生,因此代码可能有一些逻辑问题。

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

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

相关文章

声光控路灯控制系统设计与仿真

目录 前言 一、设计任务 二、系统组成及工作原理 1、总体设计思路 2、电路各模块设计简介 &#xff08;1&#xff09;光控电路 &#xff08;2&#xff09;声控电路 (3) 逻辑控制电路 (4) 延时电路 三、系统中电源模块的设计 1、方案比较和确定 2、 设计思路 3、直流…

自定义View-旋转变色圆角三角形的绘制

本文字数&#xff1a;3151字 预计阅读时间&#xff1a;20分钟 在现代设计中&#xff0c;动效图在APP的UI界面中所起到的作用无疑是显著的。相比于静态的界面&#xff0c;动效更符合人类的自然认知体系&#xff0c;它有效地降低了用户的认知负载&#xff0c;UI动效俨然已经成为了…

利用ENVI SPEAR工具和WV-2卫星影像数据量测水深

ENVI的SPEAR工具集&#xff08;(Spectral Processing Exploitation and Analysis Resource)&#xff09;是将很多的遥感图像处理过程集成为流程化的操作方式&#xff0c;使得遥感图像处理知识相对薄弱的非专业人员也能利用流程化的工具进行图像处理&#xff0c;图像处理速度也有…

自动驾驶框架 UniAD环境部署

感谢大佬们的开源工作 UniAD-github地址-YYDS更多bev算法部署参考如果您觉得本帖对您有帮助&#xff0c;感谢您一键三连支持一波^_^ 统一自动驾驶框架 (UniAD) &#xff0c;第一个将全栈驾驶任务整合到一个深度神经网络中的框架&#xff0c;并可以发挥每个子任务以及各个模块的…

[每周一更]-(第94期):认识英伟达显卡

英伟达显卡&#xff1a;引领图形计算的领先者&#xff0c;显卡也常称为GPU&#xff08;图形处理器 Graphics processing unit&#xff09;&#xff0c;是一种专门在个人电脑、工作站、游戏机和一些移动设备&#xff08;如平板电脑、智能手机等&#xff09;上执行绘图运算工作的…

【STM32+HAL】三轴按键PS2摇杆

一、准备工作&#xff1a; 有关CUBEMX的初始化配置&#xff0c;参见我的另一篇blog&#xff1a;【STM32HAL】CUBEMX初始化配置 有关定时器触发ADC模式配置&#xff0c;详见【STM32HAL】ADC采集波形实现 二、所用工具&#xff1a; 1、芯片&#xff1a; STM32F407VET6 2、CUBE…

大数据面试题 —— Spark数据倾斜及其解决方案

目录 1 调优概述2 数据倾斜发生时的现象3 数据倾斜发生的原理4 如何定位导致数据倾斜的代码4.1 某个 task 执行特别慢的情况4.2 某个 task 莫名其妙内存溢出的情况5 查看导致数据倾斜的 key 的数据分布情况6 数据倾斜的解决方案6.1 使用 Hive ETL 预处理数据6.2 过滤少数导致倾…

Ubuntu中的 Everything 搜索软件 ==> fsearch

本文所使用的 Ubuntu 系统版本是 Ubuntu 22.04 ! 在 Windows 中&#xff0c;我经常使用 Everything 来进行文件搜索&#xff0c;搜索效率比 Windows 自带的高出千百倍。 那么在 Ubuntu 系统中&#xff0c;有没有类似的软件呢&#xff1f;那必须有&#xff0c;它就是 FSearch 。…

JavaScript-Web API基本认知-什么是DOM和BOM

基本认知 var、let、const选用Web API作用和分类什么是DOM什么是DOM树DOM对象&#xff08;重要&#xff09;什么是BOM var、let、const选用 var or let or const &#xff1f; 首先var 先排除&#xff0c;老派写法&#xff0c;问题很多&#xff0c;可以淘汰掉… let or const …

Docker 的数据管理 与 Docker 镜像的创建

目录 一、Docker 的数据管理 1.1.数据卷 1.2.数据卷容器 1.3.容器互联&#xff08;使用centos镜像&#xff09; 二、Docker 镜像的创建 2.1.基于现有镜像创建 2.2.基于本地模板创建 2.3.基于Dockerfile创建 2.3.1联合文件系统&#xff08;UnionFs&#xff09; 2.3.2…

多线程模型浅谈

优质博文&#xff1a;IT-BLOG-CN 笔者近期在维护的项目中发现了一些比较随机的问题&#xff0c;时有时无的&#xff0c;排查之后发现是使用多线程导致的&#xff0c;恍然之下研究了下多线程的底层模型相关知识&#xff0c;现不大家简要分享下。 一个程序进程可包含多个线程&am…

全志ARM-超声波测距

超声波测距模块是用来测量距离的一种产品&#xff0c;通过发送和收超声波&#xff0c;利用时间差和声音传播速度&#xff0c; 计算出模块到前方障碍物的距离 1.测距原理&#xff1a; 给Trig端口至少10us的高电平发送声波&#xff0c;Echo信号&#xff0c;由低电平跳转到高电平…

【语音识别】搭建本地的语音转文字系统:FunASR(离线不联网即可使用)

参考自&#xff1a; 参考配置&#xff1a;FunASR/runtime/docs/SDK_advanced_guide_offline_zh.md at main alibaba-damo-academy/FunASR (github.com)参考配置&#xff1a;FunASR/runtime/quick_start_zh.md at 861147c7308b91068ffa02724fdf74ee623a909e alibaba-damo-aca…

绘唐科技AIGC怎么激活

绘唐科技AIGC怎么激活绘唐科技AIGC怎么激活绘唐科技AIGC怎么激活绘唐科技AIGC怎么激活 这里激活免费3天体验 Docshttps://qvfbz6lhqnd.feishu.cn/wiki/D3YLwmIzmivZ7BkDij6coVcbn7W

【Django】初识Django快速上手

Django简介 Django是一个高级的、开源的Python Web框架&#xff0c;旨在快速、高效地开发高质量的Web应用程序 https://developer.mozilla.org/zh-CN/docs/Learn/Server-side/Django/Introduction 安装Django pip install Django如果要知道安装的Django的版本&#xff0c;可…

机器学习:深入解析SVM的核心概念(问题与解答篇)【一、间隔与支持向量】

直接阅读原始论文可能有点难和复杂&#xff0c;所以导师直接推荐我阅读周志华的《西瓜书》&#xff01;&#xff01;然后仔细阅读其中的第六章&#xff1a;支持向量机 间隔与支持向量 问题一&#xff1a;什么叫法向量&#xff1f;为什么是叫法向量 在这个线性方程中&#xff…

新科技辅助器具赋能视障生活:让盲人出行融入日常

随着科技日新月异的发展&#xff0c;一款名为蝙蝠避障专为改善盲人日常生活的盲人日常生活辅助器具应运而生&#xff0c;它通过巧妙整合实时避障与拍照识别功能&#xff0c;成功改变了盲人朋友们的生活格局&#xff0c;为他们提供了更为便捷、高效的生活体验。 这款非同…

数据结构——二叉树的顺序存储(堆)(C++实现)

数据结构——二叉树的顺序存储&#xff08;堆&#xff09;&#xff08;C实现&#xff09; 二叉树可以顺序存储的前提堆的定义堆的分类大根堆小根堆 整体结构把握两种调整算法向上调整算法递归版本 非递归版本向下调整算法非递归版本 向上调整算法和向下调整算法的比较 我们接着…

1. 房屋租赁管理系统(Java项目 springboot/vue)

1.此系统的受众 1.1 在校学习的学生&#xff0c;可用于日常学习使用或是毕业设计使用 1.2 毕业一到两年的开发人员&#xff0c;用于锻炼自己的独立功能模块设计能力&#xff0c;增强代码编写能力。 1.3 亦可以部署为商化项目使用。 2. 技术栈 jdk8springbootvue2mysq5.7&8…

论文阅读之MMSD2.0: Towards a Reliable Multi-modal Sarcasm Detection System

文章目录 论文地址主要内容主要贡献模型图技术细节数据集改进多视图CLIP框架文本视图图像视图图像-文本交互视图 实验结果 论文地址 https://arxiv.org/pdf/2307.07135 主要内容 这篇文章介绍了一个名为MMSD2.0的多模态讽刺检测系统的构建&#xff0c;旨在提高现有讽刺检测系…