Web前端开发 小实训(二) 简易计算器

实训目的

学生能够使用函数完成简易计算器编写

操作步骤

1、请将加减乘除四个方法生成为以下函数,且有返回值

中文英语
加法add
减法subtract
乘法multi
除法division
次幂pow()
平方根sqrt()

提示: 除法中的除数不能为0!

参考代码:

function add(num1, num2) {
            return num1 + num2;
        }

function subtract(num1, num2) {
            return num1 - num2;
        }

function multi(num1, num2) {
            return num1 * num2;
        }

function division(num1, num2) {
            if (num2 == 0) {
                return "除数不能为0!";
            }
            return num1 / num2;
        }

function pow(num1, num2) {
            return Math.pow(num1, num2);
        }

function sqrt(num1) {
            return Math.sqrt(num1);
        }

2、使用分支语句,完成加减乘除的分类,参考如下

参考代码

function calc() {
            let choose_number = prompt("欢迎使用简易计算器!请输入你要使用的功能:\n按1进行加法;\n按2进行减法;\n按3进行乘法;\n按4进行除法;\n按5进行次幂,\n按6进行平方根计算;\n按其他数退出运算");
            let result = 0;
            let num1;
            let num2;
            switch (Number(choose_number)) {

                case 1:
                
                    break;
                case 2:
                  
                    break;
                case 3:
                    
                    break;
                case 4:
                  
                    break;
                case 5:
                    
                    break;
                case 6:
                   
                    break;
                default:
                    alert("计算结束,已退出...")
            }
        }

3、输入数字后进入到对应的功能

4、完成后输出结果

步骤3-4参考代码

switch (Number(choose_number)) {

                case 1:
                    num1 = Number(prompt("开始进行加法\n请输入第一个数"));
                    num2 = Number(prompt("请输入第二个数"));
                    result = add(num1, num2);
                    alert("你的计算结果为:" + result);
                   
                    break;
                case 2:
                    num1 = Number(prompt("开始进行减法\n请输入第一个数"));
                    num2 = Number(prompt("请输入第二个数"));
                    result = subtract(num1, num2);
                    alert("你的计算结果为:" + result);
                    isNext();
                    break;
                case 3:
                    num1 = Number(prompt("开始进行乘法\n请输入第一个数"));
                    num2 = Number(prompt("请输入第二个数"));
                    result = multi(num1, num2);
                    alert("你的计算结果为:" + result);
                  
                    break;
                case 4:
                    num1 = Number(prompt("开始进行除法\n请输入第一个数"));
                    num2 = Number(prompt("请输入第二个数"));
                    result = division(num1, num2);
                    alert("你的计算结果为:" + result);
                   
                    break;
                case 5:
                    num1 = Number(prompt("开始进行次幂\n请输入第一个数"));
                    num2 = Number(prompt("请输入第二个数"));
                    result = pow(num1, num2);
                    alert("你的计算结果为:" + result);
                   
                    break;
                case 6:
                    num1 = Number(prompt("开始进行求根\n请输入"));
                    result = sqrt(num1,);
                    alert("你的计算结果为:" + result);
                    break;

5、如果是其他数字,则退出

  default:
     alert("计算结束,已退出...")

6、正常计算结果后,提示是否继续计算,如果继续,则回到步骤1,取消结束计算

 function isNext() {
            let result = confirm("还需要继续计算吗?")
            if (result) {
                calc();
            }else{
                alert("感谢您的使用!")
            }
        }

申明方法后,在每个分支后调用

      case 1:
      num1 = parseFloat(prompt("开始进行加法\n请输入第一个数"));
                    num2 = parseFloat(prompt("请输入第二个数"));
                    result = add(num1, num2);
                    alert("你的计算结果为:" + result);
                    isNext();//继续调用
                    break;
     case 2:
                    num1 = parseFloat(prompt("开始进行减法\n请输入第一个数"));
                    num2 = parseFloat(prompt("请输入第二个数"));
                    result = subtract(num1, num2);
                    alert("你的计算结果为:" + result);
                    isNext();
                    break;
      //......              

最后直接调用运行页面

 //开始调用
calc();

完整代码

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

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>

    <script>

        function add(num1, num2) {
            return num1 + num2;
        }

        function subtract(num1, num2) {
            return num1 - num2;
        }

        function multi(num1, num2) {
            return num1 * num2;
        }

        function division(num1, num2) {
            if (num2 == 0) {
                return "除数不能为0!";
            }
            return num1 / num2;
        }

        function pow(num1, num2) {
            return Math.pow(num1, num2);
        }

        function sqrt(num1) {
            return Math.sqrt(num1);
        }

        function isNext() {
            let result = confirm("还需要继续计算吗?")
            if (result) {
                calc();
            }else{
                alert("感谢您的使用!")
            }
        }

        function calc() {
            let choose_number = prompt("欢迎使用简易计算器!请输入你要使用的功能:\n按1进行加法;\n按2进行减法;\n按3进行乘法;\n按4进行除法;\n按5进行次幂,\n按6进行平方根计算;\n按其他数退出运算");
            let result = 0;
            let num1;
            let num2;
            switch (Number(choose_number)) {

                case 1:
                    num1 = Number(prompt("开始进行加法\n请输入第一个数"));
                    num2 = Number(prompt("请输入第二个数"));
                    result = add(num1, num2);
                    alert("你的计算结果为:" + result);
                    isNext();
                    break;
                case 2:
                    num1 = Number(prompt("开始进行减法\n请输入第一个数"));
                    num2 = Number(prompt("请输入第二个数"));
                    result = subtract(num1, num2);
                    alert("你的计算结果为:" + result);
                    isNext();
                    break;
                case 3:
                    num1 = Number(prompt("开始进行乘法\n请输入第一个数"));
                    num2 = Number(prompt("请输入第二个数"));
                    result = multi(num1, num2);
                    alert("你的计算结果为:" + result);
                    isNext();
                    break;
                case 4:
                    num1 = Number(prompt("开始进行除法\n请输入第一个数"));
                    num2 = Number(prompt("请输入第二个数"));
                    result = division(num1, num2);
                    alert("你的计算结果为:" + result);
                    isNext();
                    break;
                case 5:
                    num1 = Number(prompt("开始进行次幂\n请输入第一个数"));
                    num2 = Number(prompt("请输入第二个数"));
                    result = pow(num1, num2);
                    alert("你的计算结果为:" + result);
                    isNext();
                    break;
                case 6:
                    num1 = Number(prompt("开始进行求根\n请输入第一个数"));
                    result = sqrt(num1,);
                    alert("你的计算结果为:" + result);
                    isNext();
                    break;
                default:
                    alert("计算结束,已退出...")
            }
        }

        //开始调用
        calc();
    </script>

</body>

</html>

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

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

在线培训考试系统在线考试功能注意事项

在线培训考试系统在线考试功能注意事项 考试前务必注意是否开启防切屏、摄像头监考等防作弊措施&#xff0c;系统一旦检测到触发了疑似作弊行为会立刻自动交卷&#xff0c;考试终止&#xff1b; 答题者准备好后&#xff0c;可点击“开始答题”按钮进入考试&#xff0c;注意考…

代码随想录第49天|121. 买卖股票的最佳时机 122.买卖股票的最佳时机II

121. 买卖股票的最佳时机 121. 买卖股票的最佳时机 - 力扣&#xff08;LeetCode&#xff09; 代码随想录 (programmercarl.com) 动态规划之 LeetCode&#xff1a;121.买卖股票的最佳时机1_哔哩哔哩_bilibili 给定一个数组 prices &#xff0c;它的第 i 个元素 prices[i] 表示一…

#C++里的引用#

目录 引用概念 定义引用类型 引用特性 常引用 传引用传参 传引用做返回值 1.引用概念 引用不是新定义一个变量&#xff0c;而是给已存在变量取了一个别名&#xff0c;编译器不会为引用变量开辟内存空间&#xff0c;它和它引用的变量共用同一块内存空间。 比如&#xff1a…

【AI】一文介绍索引增强生成RAG的原理和结构

今天向大家介绍一下关于RAG的一些知识和经验。 这里说的RAG可以理解为目前针对企业知识库问答等AI应用场景的解决方案,这个场景就是利用自然语言大模型LLM与用户自有的文件进行对话的能力。 【RAG的优势】 首先,讲一讲RAG的优势特征。 如果把AI想象成一个待上岗的人类助手,…

1、Flink DataStreamAPI 概述(上)

一、DataStream API 1、概述 1&#xff09;Flink程序剖析 1.Flink程序组成 a&#xff09;Flink程序基本组成 获取一个执行环境&#xff08;execution environment&#xff09;&#xff1b;加载/创建初始数据&#xff1b;指定数据相关的转换&#xff1b;指定计算结果的存储…

模型 AIPL(认知、兴趣、购买、忠诚)

系列文章 分享 模型&#xff0c;了解更多&#x1f449; 模型_思维模型目录。品牌营销的量化与链路化。 1 AIPL模型的应用 1.1 耐克如何利用AIPL模型来推广其运动鞋和服装产品? 耐克利用AIPL模型来推广其运动鞋和服装产品&#xff0c;具体如下&#xff1a; 认知&#xff08;…

为什么总说抖店做不好?做抖店需要注意这些问题,是不是都占了?

大家好&#xff0c;我是电商花花。 今天给大家总结了4个新手不注意又常犯的几个原因&#xff0c;这些建议都是我们做店这些年的实操经验&#xff0c;可以帮助大家做店自查&#xff0c;有责改之&#xff0c;无责加冕。 1、抖店核心是选品而不是玩法 很多新手在刚开始做店抖音小…

8K+/月!学习就业一把梭,祝贺誉天数通陈同学收获心仪offer !

大家好&#xff0c;我是誉天数通的陈同学。 在武汉&#xff0c;网络运维圈的人应该都会听过誉天的名字。作为华为的授权培训合作伙伴&#xff0c;誉天不仅提供专业全面的工程师培训&#xff0c;还以其独特的环境和氛围吸引着无数有志于在网络领域发展的朋友。 一年前的我&#…

用坐标与碰撞检测效果

用pygame碰撞检测子弹 与 子弹 格子检查是否在墙内 结果差不了多少 输出的是碰撞点坐标 在计算角色与强的距离是 你用了几条射线 2024/4/26 13:20:48 在代码中&#xff0c;用于计算角色与墙之间距离的部分是通过投射多条射线来实现的。具体来说&#xff0c;在循环中&#xf…

IDEA插件

POJO to JSON —— 实体转Json Smart Input —— 自动切换中英文 Translation —— 翻译 Maven Helper —— 依赖管理 .ignore —— 忽略提交文件 enum-quick-generate —— 枚举代码生成 粘贴到项目包下

前端更优雅的使用 jsonp

前端更优雅的使用 jsonp 背景&#xff1a;最近项目中又使用到了 jsonp 这一项跨域的技术&#xff0c;&#xff08;主要还是受同源策略影响&#xff09;&#xff0c;下面有为大家提供封装好的函数及对应使用示例&#xff0c;欢迎大家阅读理解 文章目录 前端更优雅的使用 jsonp同…

基于车载点云数据的城市道路特征目标提取与三维重构

作者&#xff1a;邓宇彤&#xff0c;李峰&#xff0c;周思齐等 来源&#xff1a;《北京工业大学学报》 编辑&#xff1a;东岸因为一点人工一点智能公众号 基于车载点云数据的城市道路特征目标提取与三维重构本研究旨在弥补现有研究在处理复杂环境和大数据量上的不足&#xf…

Qt设置可执行程序图标,并打包发布

一、设置图标 图标png转ico: https://www.toolhelper.cn/Image/ImageToIco设置可执行程序图标 修改可执行程序图标 添加一个rc文件,操作如下,记得后缀改为rc 打开logo.rc文件添加代码IDI_ICON1 ICON DISCARDABLE "logo.ico"在项目pro后缀名的文件中添加代码 RC_…

系统盘空间不足调优方式1-APPData/大文件清理

作者&#xff1a;私语茶馆 1.前言 Windows系统盘&#xff08;C盘&#xff09;很容易剩余空间不足&#xff0c;这种情况下会非常影响Windows系统的运行&#xff0c;系统盘约束非常多&#xff0c;不方便在线扩容&#xff0c;因此规划和利用好系统盘是保障整体运行效率的关键。包…

机器人系统开发ros2-基础实践01-学会自定义一个机器人动作aciton实体类

您之前在了解操作教程中了解了action 。与其他通信类型及其各自的接口&#xff08;主题/消息和服务/srv&#xff09;一样&#xff0c;您也可以在包中自定义操作。本教程向您展示如何定义和构建可与您将在下一个教程中编写的action服务器和action 客户端一起使用的操作。 需要理…

Rust 实战练习 - 12. Axum Web 简单demo

Rust Web 历程 Rust 的异步框架tokio非他莫属&#xff0c;而web框架一直是悬而未决&#xff0c;说到底还是因为没有官方成熟的方案指引&#xff0c;大家各玩各的&#xff0c;互不兼容&#xff0c;白白浪费精力。 这个事情一直等到半官方组织tokio推出axum有了改善。但是市场上…

LeetCode455:分发饼干

题目描述 假设你是一位很棒的家长&#xff0c;想要给你的孩子们一些小饼干。但是&#xff0c;每个孩子最多只能给一块饼干。 对每个孩子 i&#xff0c;都有一个胃口值 g[i]&#xff0c;这是能让孩子们满足胃口的饼干的最小尺寸&#xff1b;并且每块饼干 j&#xff0c;都有一个…

Orange3数据可视化(组件概览)

概要 大家见过Orange3提供的丰富数据可视化组件吗&#xff1f; Orange3为您提供了一系列生动的图表工具&#xff0c;包括树图、箱线图、小提琴图、分布图、散点图、折线图、条形图、筛图、马赛克图、自由投影、线性投影、雷达图、热力图、韦恩图、轮廓图、毕达哥拉斯树、毕达哥…

关于springboot内置tomcat最大请求数配置的一些问题

前言 springboot内置了tomcat。那么一个springboot web应用&#xff0c;最大的请求链接数是多少呢&#xff1f;很早以前就知道这个是有个配置&#xff0c;需要的时候&#xff0c;百度一下即可。但&#xff0c;事实并非如此&#xff0c;有几个问题我想大多数人还真不知道。比如…

强化学习-MAPPO算法解析与实践-Multi Agent Proximal Policy Optimization

一 算法简介 mappo 是一种将ppo算法扩展到多智能体情况的算法&#xff0c;在讨论过这种算法的论文中&#xff0c;比较有名和权威的是Nips2021上发表的《The Surprising Effectiveness of PPO in Cooperative》。比较遗憾的是&#xff0c;可能作者出于自己不是最早提出mappo算法…