网页计算器的实现

简介

该项目实现了一个功能完备、交互友好的网页计算器应用。只使用了 HTML、CSS 和 JavaScript ,用于检验web前端基础水平。

  • 开发环境:Visual Studio Code
  • 开发工具:HTML5、CSS3、JavaScript
  • 实现效果
    在这里插入图片描述

功能设计和模块划分

  1. 显示模块:负责展示输入的数字和计算结果。
  2. 输入模块:处理用户点击数字和运算符按钮的操作。
  3. 计算模块:执行具体的数学运算,并处理异常情况。

具体实现

  1. 项目结构
    在这里插入图片描述
  2. index.html
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>计算器</title>
    <link rel="stylesheet" href="./css/index.css">
    <script src="./js/index.js"></script>
</head>

<body>
    <div id="outer">
        <!-- 显示 -->
        <div class="screen">
            <div class="showNum">0</div>
        </div>
        <!-- 按钮 -->
        <div class="buttons">
            <input type="button" value="AC" class="btn1">
            <input type="button" value="<-" class="btn1">
            <input type="button" value="+/-" class="btn1">
            <input type="button" value="/" class="btn2">

            <input type="button" value="1">
            <input type="button" value="2">
            <input type="button" value="3">
            <input type="button" value="*" class="btn2">

            <input type="button" value="4">
            <input type="button" value="5">
            <input type="button" value="6">
            <input type="button" value="-" class="btn2">


            <input type="button" value="7">
            <input type="button" value="8">
            <input type="button" value="9">
            <input type="button" value="+" class="btn2">


            <input type="button" value="0">
            <input type="button" value=".">
            <input type="button" value="m">
            <input type="button" value="=" class="btn2">
        </div>

    </div>

</body>

</html>
  1. index.css
/* 去除默认样式 */
* {
    padding: 0;
    margin: 0;
}

input {
    border: 0;
}

/* 外部轮廓的样式 */
#outer {
    width: 380px;
    height: 640px;
    background-color: black;
    /* 居中 */
    margin: 0 auto;
    /* 设置圆角效果 */
    border-radius: 30px;

}

/* 显示样式 */
.screen {
    width: 380px;
    height: 180px;
    /* 开启相对定位 */
    position: relative;
}

.showNum {
    color: white;
    font-size: 60px;
    /* 开启绝对定位 */
    position: absolute;
    right: 30px;
    bottom: 10px;
}

/* 按钮样式 */
.buttons {
    height: 440px;
    /* 设置内边距 */
    padding: 10px;
    /* 开启弹性盒子 */
    display: flex;
    /* 自动换行 */
    flex-wrap: wrap;
    /* 水平方向设置两端对齐 */
    justify-content: space-between;
    /* 垂直方向两端对齐 */
    align-content: space-between;
}

.buttons>input {
    width: 80px;
    height: 80px;
    background-color: rgb(51, 51, 51);
    /* 设置圆形 */
    border-radius: 50%;
    /* 设置字体颜色 */
    color: white;
    /* 设置字体大小 */
    font-size: 28px;
}

.buttons>.btn1 {
    color: black;
    background-color: rgb(165, 164, 164);
}

.buttons>.btn2 {
    background-color: rgb(213, 158, 90);
}

/* 设置点击高亮效果 */
.buttons>input:active {
    filter: brightness(140%);
}
  1. index.js
window.addEventListener("load", function () {
  let showNum = document.querySelector(".showNum");
  // 利用事件委托,给按钮共同的祖先元素绑定事件,利用事件冒泡完成对应的事件回调
  let buttons = document.querySelector(".buttons");
  //定义一个标志符
  let flag = false;
  buttons.addEventListener("click", function (e) {
    let buttonValue = e.target.value;
    let showNumValue = showNum.innerHTML;
    // 1.判断如果点击的是数字,则显示
    if (!isNaN(buttonValue)) {
      // 2.屏幕显示数字是否是0
      if (showNumValue == 0) {
        showNum.innerHTML = buttonValue;
      } else {
        showNum.innerHTML = showNumValue + buttonValue;
      }
    } else {
      //点击功能按钮
      switch (buttonValue) {
        case "AC": //清零
          showNum.innerHTML = 0;
          break;
        case "<-":
          showNum.innerHTML = delOneFun(showNumValue);
          break;
        case "+/-":
          showNum.innerHTML = showNumValue * -1;
          break;
        case ".":
          showNum.innerHTML = pointFun(showNumValue);
          break;
        case "m":
          location.href = "https://www.baidu.com";
          break;
        default:
          switch (buttonValue) {
            case "/":
            case "*":
            case "-":
            case "+":
              flag = true;
              showNum.innerHTML = showNumValue + buttonValue;
              break;
            case "=":
              showNum.innerHTML = evalFun(showNumValue);
              break;
          }
          break;
      }
    }
  });
  //退格函数
  function delOneFun(value) {
    let newValue = value.substring(0, value.length - 1);
    if (newValue.length == 0) {
      newValue = 0;
    }
    return newValue;
  }
  //小数点
  function pointFun(value) {
    let newValue = "";
    if (value.indexOf(".") == -1) {
      newValue = value + ".";
    } else if (flag) {
      newValue = value + ".";
      flag = false;
    } else {
      return value;
    }

    return newValue;
  }
  //运算函数
  function evalFun(value) {
    let newValue = "";
    // eval()可以接收一个字符串作为js的代码执行
    newValue = eval(value);
    // Number.isInteger() 判断一个数字是否是整数,如果是则返回true
    if (Number.isInteger(newValue)) {
      return newValue;
    } else {
      // toFixed()保留指定位数的小数
      newValue = newValue.toFixed(2);
      return newValue;
    }
  }
});

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

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

相关文章

Chapter11让画面动起来——Shader入门精要学习笔记

Chapter11让画面动起来 一、Unity Shader中的内置变量&#xff08;时间篇&#xff09;二、纹理动画1.序列帧动画2.滚动背景 三、顶点动画1.流动的河流2.广告牌3.注意事项①批处理问题②阴影投射问题 一、Unity Shader中的内置变量&#xff08;时间篇&#xff09; Unity Shader…

Chiasmodon:一款针对域名安全的公开资源情报OSINT工具

关于Chiasmodon Chiasmodon是一款针对域名安全的公开资源情报OSINT工具&#xff0c;该工具可以帮助广大研究人员从各种来源收集目标域名的相关信息&#xff0c;并根据域名、Google Play应用程序、电子邮件地址、IP地址、组织和URL等信息进行有针对性的数据收集。 该工具可以提…

window系统openssl开发环境搭建(VS2017)

window系统openssl开发环境搭建 VS2017 一、下载openssl二、安装openssl三、openssl项目配置3.1 配置include文件3.2 配置openssl动态库四、编写openssl测试代码五、问题总结5.1 问题 一5.2 问题二一、下载openssl https://slproweb.com/products/Win32OpenSSL.html 根据自己…

如何查看MCU编译生成的elf(out)文件内容

一般地&#xff0c;我们想要知道单片机程序编译完后的结构我们可以查看map文件或者是elf/out文件&#xff0c;map文件不能看函数的汇编格式&#xff0c;只能查看编译完成后变量、代码的地址和占用空间大小&#xff0c;而elf文件里面更加详细&#xff0c;还包含了函数的汇编&…

CobaltStrike的内网安全

1.上线机器的Beacon的常用命令 2.信息收集和网站克隆 3.钓鱼邮件 4.CS传递会话到MSF 5.MSF会话传递到CS 1上线机器的Beacon的常用命令 介绍&#xff1a;CobaltStrike分为服务端和客户端&#xff0c;一般我们将服务端放在kali&#xff0c;客户端可以在物理机上面&#xff0…

跨境人最怕的封店要怎么规避?

跨境人最怕的是什么&#xff1f;——封店 造成封店的原因很多&#xff0c;IP关联、无版权售卖、虚假发货等等&#xff0c;其中IP关联这个问题导致店铺被封在跨境商家中简直是屡见不鲜 IP关联&#xff0c;是指被海外平台检测到多家店铺开设在同一个站点上的情况。我们知道有些…

您的私人办公室!-----ONLYOFFICE8.1版本的桌面编辑器测评

随时随地创建并编辑文档&#xff0c;还可就其进行协作 ONLYOFFICE 文档是一款强大的在线编辑器&#xff0c;为您使用的平台提供文本文档、电子表格、演示文稿、表单和 PDF 编辑工具。 网页地址链接&#xff1a; https://www.onlyoffice.com/zh/office-suite.aspxhttps://www…

“拆分盘投资:机遇与风险并存

一、引言 随着互联网技术的日新月异&#xff0c;金融投资领域迎来了前所未有的变革&#xff0c;其中拆分盘作为一种新兴的投资模式&#xff0c;正逐渐进入公众的视野。其独特的价值增长逻辑和创新的投资机制&#xff0c;为投资者开辟了新的财富增值渠道。本文旨在深入探讨拆分…

tinyshop商城学习

1、使用badboy屏幕录制工具&#xff0c;获得服装购物业务的结果&#xff0c;生成.jmx文件 2、在JMeter中新建线程组&#xff0c;导入.jmx文件 3、完成进入商城&#xff0c;登录&#xff0c;服装页面进入&#xff0c;随机选择服装&#xff0c;添加购物车&#xff0c;开始结算&…

WAIC上官宣!大模型语料提取工具MinerU正式发布,开源免费“敲”好用

7月4日&#xff0c;2024 WAIC科学前沿全体会议在上海世博中心红厅隆重举行。上海人工智能实验室与商汤科技联合香港中文大学和复旦大学正式发布新一代大语言模型书⽣浦语2.5&#xff08;InternLM2.5&#xff09;&#xff0c;同时全链条工具体系迎来重磅升级&#xff0c;对于大模…

第六篇——谋攻篇:上兵伐谋,不是说打仗要用计谋

目录 一、背景介绍二、思路&方案三、过程1.思维导图2.文章中经典的句子理解3.学习之后对于投资市场的理解4.通过这篇文章结合我知道的东西我能想到什么&#xff1f; 四、总结五、升华 一、背景介绍 战术层面的东西&#xff0c;即便战略对了&#xff0c;战术不对&#xff0…

公司管理系统

准备工作 上图mapper类型错了&#xff0c;不是class&#xff0c;是interface&#xff0c;修正过后的图片&#xff0c;如下所示 修正如下 spring.datasource.driver-class-namecom.mysql.cj.jdbc.Driver spring.datasource.urljdbc:mysql://localhost:3306/webm spring.datasour…

CAN总线(上)

CAN总线&#xff08;Controller Area Network Bus&#xff09;控制器局域网总线 CAN总线是由BOSCH公司开发的一种简洁易用、传输速度快、易扩展、可靠性高的串行通信总线&#xff0c;广泛应用于汽车、嵌入式、工业控制等领域 CAN总线特征&#xff1a; 两根通信线&#xff08;…

关于ORACLE单例数据库中的logfile的切换、删除以及添加

一、有关logfile的状态解释 UNUSED&#xff1a; 尚未记录change的空白group&#xff08;一般会出现在loggroup刚刚被添加&#xff0c;或者刚刚使用了reset logs打开数据库&#xff0c;或者使用clear logfile后&#xff09; CURRENT: 当前正在被LGWR使用的gro…

产科管理系统 专科电子病历系统源码,前后端分离架构,多家医院产科广泛运用,系统稳定,功能齐全

产科管理系统 专科电子病历系统源码&#xff0c;前后端分离架构&#xff0c;多家医院产科广泛运用&#xff0c;系统稳定&#xff0c;功能齐全 产科管理系统&#xff0c;特别是产科信息管理系统&#xff08;Obstetrical Information Management System&#xff0c;简称OIMS&…

建智慧医院核心:智能导航系统的功能全析与实现效益

在数字化转型的浪潮中&#xff0c;智慧医院的建设是医疗行业数字化转型的关键步骤。随着医院规模的不断扩大和医疗设施的日益复杂&#xff0c;传统的静态不连续的导航方式已无法满足患者的需求。院内智能导航系统&#xff0c;作为医疗数字化转型的关键组成部分&#xff0c;正逐…

2024骨传导耳机品牌排行榜!盘点10款优质热门机型推荐!

骨传导耳机逐渐成为当下最受欢迎的热门机型&#xff0c;但随着耳机热度的增高&#xff0c;市面上一些不法商家仿佛看到了商机&#xff0c;纷纷投入骨传导耳机市场&#xff0c;这也导致骨传导耳机市场出现鱼龙混杂&#xff0c;劣质品牌横行的局面&#xff0c;纷纷有消费者反馈说…

android2024 gradle8 Processor和ksp两种编译时注解实现

android的编译时注解&#xff0c;老生常谈&#xff0c;外面的例子都是bindView&#xff0c;脑壳看疼了&#xff0c;自己学习和编写下。 而且现在已经进化到kotlin2.0了&#xff0c;google也逐渐放弃kapt&#xff0c;进入维护状态。所以要好好看看本贴。 参考我的工程&#xff1…

djangoGD高校信管专业就业信息管理系统-计算机毕业设计源码59343

djangoGD高校信管专业就业信息管理系统 摘 要 随着高校信管专业的快速发展&#xff0c;学生就业问题日益受到广泛关注。为了更好地服务学生&#xff0c;提高就业率&#xff0c;许多高校开始引入信息化手段来管理学生就业信息。然而&#xff0c;传统的就业信息管理方式存在很多问…

Linux关于文件的高级命令

tree命令 tree命令用于以树状图的形式显示目录结构。它可以帮助用户快速了解目录和文件的层次关系&#xff0c;非常适合用于浏览和理解大型文件系统的结构。 基础用法 显示当前目录的树状结构&#xff1a;tree 显示指定目录的树状结构&#xff1a;tree 指定目录路径 tree命…