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

devtools/2024/9/23 9:36:59/

用于学生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.ppmy.cn/devtools/26377.html

相关文章

Visual studio 2019 编程控制CH341A芯片的USB设备

1、硬件 买了个USB可转IIC、或SPI、或UART的设备&#xff0c;主芯片是CH341A 主要说明USB转SPI的应用&#xff0c;绿色跳线帽选择IIC&SPI&#xff0c;用到CS0、SCK、MOSI、MISO这4个引脚 2、软件 2.1、下载CH341A的驱动 点CH341A官网https://www.wch.cn/downloads/CH34…

经典网络解读——Efficientnet

论文&#xff1a;EfficientNet: Rethinking Model Scaling for Convolutional Neural Networks&#xff08;2019.5&#xff09; 作者&#xff1a;Mingxing Tan, Quoc V. Le 链接&#xff1a;https://arxiv.org/abs/1905.11946 代码&#xff1a;https://github.com/tensorflow/t…

torch.cuda.is_available()返回flase 问题排查

查看torch版本是否为GPU版本 import torch print(torch.__version__)如果不是GPU版本下载GPU版本 查看cuda版本 nvcc --version下载cuda对应的cuda版本 nvcc: NVIDIA (R) Cuda compiler driver Copyright (c) 2005-2022 NVIDIA Corporation Built on Wed_Sep_21_10:41:10_P…

『FPGA通信接口』DDR(3)DDR3颗粒读写测试

文章目录 前言1.配套工程简介2.测试内容与策略3. 测试程序分析4.程序结果分析5.一个IP控制两颗DDR36.传送门 前言 以四颗MT41K512M16HA-125AIT颗粒为例&#xff0c;介绍如何在一块新制板卡上做关于DDR3的器件测试。前面两篇介绍了什么是DDR&#xff0c;并介绍了xilinx给出的FPG…

Qt5配置Opencv读取一张图像

1、首先Qt5配置Opencv(我已经配置成功)有时间发出来 2、Opencv的基本Mat操作 &#xff08;1&#xff09;加Opencv的头文件 #include<opencv2/opencv.hpp> #include <opencv2/highgui/highgui_c.h> using namespace cv;&#xff08;2&#xff09;Opencv图像基本处理…

【docker】Spring Boot3.x 打包 Docker容器

Docker化Spring Boot应用 创建文件夹 demo mkdir democd demo创建Dockerfile # 两个 openjdk 二选一 #FROM openjdk:17-jre-alpineFROM eclipse-temurin:17MAINTAINER chengxuyuanshitang <chengxuyuanshitangXX.com>RUN mkdir -p /workspace/java/demoCOPY demo.ja…

基于EBAZ4205矿板的图像处理:03使用VIO调试输出HDMI视频图像

基于EBAZ4205矿板的图像处理&#xff1a;03使用VIO调试输出HDMI视频图像 在zynq调试时VIO是真的方便&#xff0c;特此写一篇博客记录一下 先看效果 项目简介 下面是我的BD设计&#xff0c;vtc用于生成时序&#xff0c;注意&#xff0c;2021.2的vivado的vtcIP是v6.2版本&…

windows驱动开发-电源状态(一)

在windows设备驱动开发中&#xff0c;随着笔记本电脑的普及&#xff0c;低功耗要求的增加&#xff0c;设备电源状态越来越重要&#xff0c;和之前不一样&#xff0c;在以前&#xff0c;驱动仅仅只处理PNP的电源状态而已&#xff0c;现在需要处理非常多的电源状态和请求。 系统…