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

用于学生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.mzph.cn/pingmian/4197.shtml

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

相关文章

springboot如何使用RedisTemplate

第一步&#xff1a;创建一个spring boot项目 第二步&#xff1a;pom导入redis相关依赖 <!--reids依赖--> <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId> </depen…

Go语言中的goroutine调度是如何实现的?

文章目录 一、M:N调度模型二、GMP模型三、调度过程四、调度优化五、示例代码 在Go语言中&#xff0c;goroutine是一种轻量级的线程&#xff0c;它使得并发编程变得更加简单和高效。而goroutine的调度则是Go运行时&#xff08;runtime&#xff09;系统负责的一个核心任务&#x…

std::remove_if

template <class ForwardIterator, class UnaryPredicate>ForwardIterator remove_if (ForwardIterator first, ForwardIterator last,UnaryPredicate pred);std::remove_if函数删除容器中满足pred的元素&#xff0c;返回最后一个没被移除的元素后面一个迭代器&#xff0…

阿米巴经营之深入解读

目录 什么是阿米巴&#xff1f; 一、阿米巴经营的来历 二、阿米巴经营的三大好处和运作方式 三、阿米巴经营常见的两大问题与解决方案 稻盛和夫被誉为日本的经营之神。上个世纪&#xff0c;他创办经营的京瓷公司、KDDI公司等&#xff0c;先后成为了世界500强企业。2010年&…

Postman,一个功能强大的API开发和测试工具

最近有小伙伴说在找 postman 的使用教程&#xff0c;案例等文章。 那么今天我就来写一个。 Postman 是一个功能强大的 API 开发和测试工具&#xff0c;它提供了丰富的功能&#xff0c;帮助开发人员更好地管理、测试和文档化 API。无论是单独开发还是团队协作&#xff0c;Postma…

[1688]jsp工资投放管理系统Myeclipse开发mysql数据库web结构java编程计算机网页项目

一、源码特点 JSP 工资投放管理系统是一套完善的java web信息管理系统&#xff0c;对理解JSP java编程开发语言有帮助&#xff0c;系统具有完整的源代码和数据库&#xff0c;系统主要采用B/S模式开发。开发环境为 TOMCAT7.0,Myeclipse8.5开发&#xff0c;数据库为Mysql5.0…

Java读取网址信息

Java读取网址信息 今天的需求是根据接口获取JSON数据并存入&#xff0c;之前只会前端用Ajax或者Axios去处理显示出来没想过后端也要拿&#xff0c;没有思路于是查找&#xff0c;发现都是基础以前用的还是太少了&#xff0c;特此总结&#xff0c;后续有需要再补充。 1.读取get请…

vue都有那些指令?

Vue的指令是用于在HTML模板中添加特定功能的特殊属性。Vue提供了一些内置的指令&#xff0c;同时也支持自定义指令。以下是一些常用的Vue指令&#xff1a; v-bind&#xff1a;用于动态绑定HTML元素的属性。可以将Vue实例中的数据绑定到HTML元素的属性上&#xff0c;实现数据的动…

黑马面试篇

课程地址&#xff1a;新版Java面试专题视频教程&#xff0c;java八股文面试全套真题深度详解&#xff08;含大厂高频面试真题&#xff09;_哔哩哔哩_bilibili 课程名称&#xff1a;新版Java面试专题视频教程&#xff0c;java八股文面试全套真题深度详解&#xff08;含大厂高频…

【Kotlin】Flow简介

1 前言 Flow 是 Kotlin 标准库中的一个新的异步流处理框架&#xff0c;旨在简化异步数据流的操作和处理&#xff0c;它提供了一种声明式的方式来处理数据流。 Flow 中一些接口调用有些类似 Sequence&#xff08;详见 → Sequence简介&#xff09;&#xff0c;协程的使用详见 →…

Flutter - 折叠面板

demo 地址: https://github.com/iotjin/jh_flutter_demo 代码不定时更新&#xff0c;请前往github查看最新代码 flutter 自定义折叠组件 支持三种类型和两种展示效果可自定义title和被折叠的内容 效果图 示例 import package:flutter/material.dart; import /jh_common/widge…

K8s: 从集群外部访问Service

从集群外部访问 Service 1 &#xff09;概述 在前面我们一直实践的是在集群内部访问 Service&#xff0c;之前有2种方法 方法1&#xff1a;在一个node节点上&#xff0c;通过对创建的的时候&#xff0c;对port进行一个环境变量的注册来保证Service能够正确对 不同的pod 访问到…

基于SNAP使用SAR数据做变化检测change detection

基于SNAP使用SAR数据做变化检测change detection 1. 前言2. 步骤2.1 添加数据2.2 辐射定标--散斑过滤--地形矫正2.3 裁剪2.4 变化检测 3.查看变化检测结果 1. 前言 在SNAP中&#xff0c;change detection主要通过Stack工具来完成。 SAR数据&#xff1a;Radarsat-2 SLC 其他数据…

基于FastGPT搭建知识库问答系统

什么是 FastGPT &#xff1f; FastGPT 是一个基于 LLM 大语言模型的知识库问答系统&#xff0c;提供开箱即用的数据处理、模型调用等能力。同时可以通过 Flow 可视化进行工作流编排&#xff0c;从而实现复杂的问答场景&#xff01; FastGPT 允许用户构建本地知识库&#xff0c;…

conda创建新环境

&#xff11;、创建虚拟环境&#xff1a; Anaconda创建环境&#xff1a;比如&#xff0c;创建pyhon&#xff1d;3.6的版本环境取名叫 name conda create -n name python3.6 2、删除虚拟环境操作&#xff1a;&#xff08;谨慎操作&#xff09; conda remove -n name --all &am…

MQTT数据传输Payload的常见格式介绍

使用MQTT client过程中看到常见的数据格式&#xff1a; 下面是介绍 Plaintext&#xff08;纯文本&#xff09; 介绍&#xff1a;纯文本编码是最基本的编码形式&#xff0c;它使用标准的ASCII或Unicode字符来表示数据。这种编码格式是人类可读的&#xff0c;因为它直接表示文本信…

(成品论文22页)24深圳杯数学建模A题1-4问完整代码+参考论文重磅更新!!!!

论文如下&#xff1a; 基于三球定位的多个火箭残骸的准确定位 针对问题一&#xff1a;为了进行单个残骸的精确定位&#xff0c;确定单个火箭残骸发生音爆 时的精确位置和时间&#xff0c;本文基于三球定位模型&#xff0c;考虑到解的存在性和唯一性&#xff0c; 选取了四个监测…

洛谷 B3969 [GESP202403 五级] B-smooth 数 题解

思路 我们只要求出每个数的最大质因数&#xff0c;再一个个判断是否满足要求即可。 如何找到每个数的最大质因数呢&#xff1f;其实&#xff0c;我们可以在埃氏筛法的基础上进行改进&#xff0c;从而达到算出最大质因数的目的。 让我们先来了解一下埃氏筛法&#xff0c;知道…

第七篇、animateDiff使用

1、文生图 2、提示词游历 在不同帧设置不同的提示词&#xff0c;有公共提示词和游历提示词&#xff0c;上面是公共的&#xff0c;下面是游历

C#中如何定义带参数的EventHandler?

简述 事件调用的所有方法都需要两个参数&#xff1a;object sender&#xff0c;EventArgs e。该事件使用这两个参数调用方法&#xff0c;因此我们不能直接添加自定义参数。 比如下面这段代码&#xff0c;我们想在 MessageBox 中显示字符串 s &#xff0c;这必然是不成。 priv…