<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>计算器</title>
    <style>
        .wrapper{
            width: 200px;
            height: 350px;
            background-color: rgb(65, 65, 65);
            margin:  auto ;
            border-radius: 10px;
            /* overflow: hidden; */
        }
        .system{
            width: 100%;
            height: 20px;
            padding-top: 6px;
            padding-left: 5px;
        }
        .sbtn{
            width: 12px;
            height: 12px;
            background-color: rgb(92, 92, 92);
            border-radius: 50%;
            float: left;
            margin: 2px;
            
        }
        .sbtn:hover{
            background-color: red;
        }
        .display{
            width: 100%;
            height: 80px;
            color: white;
            font-size: 32px;
            text-align: right;
            line-height: 100px;
            padding: 0 10px;
            box-sizing: border-box;
            /* vertical-align: bottom; */
        }
        .control{
            width: 100%;
            height: 250px;
            color: white;
        }
        .control-button{
            width: 25%;
            height: 20%;
            float: left;
            text-align: center;
            line-height: 50px;
            background-color: rgb(113, 113, 113);
            border: 1px solid rgb(65, 65, 65);
            box-sizing: border-box;
        }
        .control-button:hover{
            background-color: yellow;
        }
        /* .control-button:active{
            
        } */
        .o1{
            background-color: rgb(85, 85, 85);
            
        }
        .o2{
            background-color: rgb(255, 157, 0);
        }
        .b2{
            width: 50%;
        }
        .left-bottom{
            border-bottom-left-radius: 10px;
        }
        .right-bottom{
            border-bottom-right-radius: 10px;
        }
    </style>
</head>
<body>
    <!-- .wrapper>.system+.display+.control -->
    <!-- .wrapper>(.system>.sbtn*3)+.display+(.control>.control-button*19) -->
    <div class="wrapper">
        <div class="system">
            <div class="sbtn"></div>
            <div class="sbtn"></div>
            <div class="sbtn"></div>
        </div>
        <div class="display"></div>
        <div class="control">
            <div class="control-button o1" onclick="acClick(this)">AC</div>
            <div class="control-button o1">+/-</div>
            <div class="control-button o1">%</div>
            <div class="control-button o2" onclick="operatorClick(this)">/</div>
            <div class="control-button" onclick="numberClick(this)">7</div>
            <div class="control-button" onclick="numberClick(this)">8</div>
            <div class="control-button" onclick="numberClick(this)">9</div>
            <div class="control-button o2" onclick="operatorClick(this)">*</div>
            <div class="control-button" onclick="numberClick(this)">4</div>
            <div class="control-button" onclick="numberClick(this)">5</div>
            <div class="control-button" onclick="numberClick(this)">6</div>
            <div class="control-button o2" onclick="operatorClick(this)">-</div>
            <div class="control-button" onclick="numberClick(this)">1</div>
            <div class="control-button" onclick="numberClick(this)">2</div>
            <div class="control-button" onclick="numberClick(this)">3</div>
            <div class="control-button o2" onclick="operatorClick(this)">+</div>
            <div class="control-button b2 left-bottom" onclick="numberClick(this)">0</div>
            <div class="control-button">.</div>
            <div class="control-button o2 right-bottom" onclick="equalClick(this)">=</div>
        </div>
    </div>
    <script>
        let firstNumber = 0;
        let buttonType = 0;
        let operatorType = "+";
        //三种选择方法
        let display = document.getElementsByClassName('display')[0];//通过 标签 id 等
        // let display = document.querySelectorAll('.display')[0];//
        // let display = document.querySelector('.display');//只会命中第一个找到的数据 另外的都会选择所有
        function numberClick(button){
            console.log(button.innerText)//innerHTML会把所有标签结构打出来.innerText只会取内容.
            if(buttonType == 0){
                display.innerText += button.innerText;
            }else{
                display.innerText = button.innerText;
            }
            buttonType == 0;
        }
        function operatorClick(button){
            console.log("1")
            firstNumber = display.innerText;
            buttonType = 1;
            operatorType = button.innerText;
        }
        function equalClick(button){
            console.log("1")
            let result = 0;
            firstNumber = parseInt(firstNumber);
            secondNumber = parseInt(display.innerText);
            expression = 'result = firstNumber' + operatorType + 'secondNumber';
            eval(expression);//字符串作为代码运行
            display.innerText = result;
            buttonType = 1;
        }
        function acClick(button){
            firstNumber = 0;
            buttonType = 0;
            operatorType = '+';
            display.innerText = '';
        }
    </script>
</body>
</html>

7.29-bug计算器的更多相关文章

  1. 基于SpringBoot+Mybatis+AntDesign快速开发平台,Jeecg-Boot 1.1 版本发布

    Jeecg-Boot 1.1 版本发布,初成长稳定版本 导读     平台首页UI升级,精美的首页支持多模式 提供4套代码生成器模板(支持单表.一对多) 集成Excel简易工具类,支持单表.一对多导入 ...

  2. Linux常用到的一些命令

    1.poweroff 关闭系统(1) 2.halt 关闭系统(2) 3.reboot 重启系统 4.pwd 查看当前所在目录的绝对路径 5.mkdir 文件名 创建一个目录文件 6.rm 文件名 删除 ...

  3. 2022-7-14 java_2 第七组 刘昀航

    @ 目录 一.java约定规范 1.关于建包 2.控制台输入(Scanner) 关于Scanner的bug 计算器小练习: 二. 1.数组 建立数组的三种方式: 数据类型的初始值: 2.二维数组 使用 ...

  4. C#委托的最简单入门和理解

      委托是.net语言中非常重要的一个概念,初学不太好理解也没有关系的,在一次一次的攻关后会领会到委托的精妙,可以说 .net 没有委托就没有后面更高级的事件,异步多线程等等特性的形成可能.所以一定要 ...

  5. 微信小程序计算器Bug版=-=(笔记)

    微信小程序计算器BUG版本 无APPID的测试号登录,先在app.json中更改路径,以及修改头部信息. 首先一个输入框字段用{{screenData}} 功能可以退格,清屏,正负号,正常操作加减乘除 ...

  6. python预科前三天:计算器知识、Python下载和安装、Pycharm下载安装激活设置、解释型和编译型、git、思维导图、显示隐藏文件、隐藏已知文件扩展名、创建组织、创建项目、提交作业、排BUG技巧

    1.计算机组成结构:CPU.硬盘.内存.输入输出设备.主板.电源. 2.硬件之间的协作关系:是CPU运算完后给操作系统.专业术语叫指令. 3.键盘输入a之后发生的事情:键盘-CPU-操作系统-显卡-显 ...

  7. 大一C语言学习笔记(10)---编程篇--制作简易计算器,支持加,减,乘,除,取余运算,要求 0 bug

    博主自开学初就一直在努力为自己的未来寻找学习方向,学习编程嘛,尽量还是要抱大腿的,所以我就加入了我们学校的智能设备研究所,别的不说,那的学长们看起来是真的很靠谱,学长们的学习氛围也超级浓厚,所以我就打 ...

  8. ★房贷计算器 APP

    一.目的 1. 这是一个蛮有用的小工具 2. 之前看了很多demo,第一次来完全的自己实现一个APP 3. 完成之后提交 App Store 4. 作为Good Coder的提交审核材料 二.排期 周 ...

  9. 计算器work_day05

    day_work_05 ------Python是一个优雅的大姐姐 作业计算器 设计思路 按照运算优先级和正则先算括号内的值,提出来判断符号问题,然后依次计算. 分析题目设计了四个函数,分别为a)去括 ...

  10. 那些年黑了你的微软BUG

    本文为 Dennis Gao 原创技术文章,发表于博客园博客,未经作者本人允许禁止任何形式的转载. 前言 炎炎夏日,朗朗乾坤,30℃ 的北京,你还在 Coding 吗? 整个 7 月都在忙项目,还加了 ...

随机推荐

  1. 3分钟教你安装 Dropzone4 文件拖拽增强工具 中文破解版 亲测有效

    Dropzone下载 下载直通车:立即下载 安装教程 打开我给你提供的Dropzone4 安装包 鼠标选中第一个程序拖到第二个程序里 在启动台打开 会出现下面情况 不要慌 点击好  去访达找到对应的软 ...

  2. CentOS安装mysql、MariaDB以及更改数据库存储路径

    注意:此方法只适用于新的机器或没有重要数据库表(可随意删除)的机器安装,如需升级版本参考下方链接!!! https://www.jianshu.com/p/955ff6065935 一.安装操作 1. ...

  3. Android  JetPack~ LiveData (一)   介绍与使用

    一般情况下LiveData都是搭配这ViewModel使用,这里先介绍一下LiveData,再结合ViewModel使用 Android数据绑定技术一,企业级开发 Android数据绑定技术二,企业级 ...

  4. 浏览界面servlet实现

    <%@ page language="java" contentType="text/html; charset=UTF-8" pageEncoding= ...

  5. Centos8安装nvidia驱动

    Centos8安装nvidia驱动 1. 查看显卡型号 lspci | grep-i nvidia 或者 lspci -vnn | grep VGA 2. 前往nvidia官网下载对应驱动 NVIDI ...

  6. Nacos服务发现原理分析

    微服务将自己的实例注册到nacos注册中心,nacos服务端存储了注册列表,然后通过ribbon调用服务,具体是如何调用?如果nacos服务挂了,还能正常调用服务吗?调用的服务列表发生变化,调用方是如 ...

  7. P2617 Dynamic Rankings 解题报告

    link 整体二分是一种东西,比如上面这道题. 先考虑一个不带修版本的,也就是经典问题区间 kth,显然我们可以主席树但是我知道你很想用主席树但是你先别用不用主席树,用一种离线的算法,叫整体二分. 首 ...

  8. 题解 P4163 [SCOI2007]排列

    强烈谴责只有 125MB 的行为,然后我没删调试是个什么 SB... 闲话少说,切入正题-- 首先看到取余和数字是可以排列的,我们自然而然的想到了数位 dp,但是很显然这题不是的数位 dp 通常解决的 ...

  9. 如何把已安装的nodejs高版本降级为低版本(图文教程)

    第一步.先清空本地安装的node.js版本 1.按健win+R弹出窗口,键盘输入cmd,然后敲回车(或者鼠标直接点击电脑桌面最左下角的win窗口图标弹出,输入cmd再点击回车键) 2.然后进入命令控制 ...

  10. LeetCode-1719 重构一棵树的方案数

    来源:力扣(LeetCode)链接:https://leetcode-cn.com/problems/number-of-ways-to-reconstruct-a-tree 题目描述 给你一个数组  ...