JavaScript 计算器的制作及详细解释 适合你

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>简易计算器</title>
<style>
.calculator { /*盒子的类*/
width: 500px;
height: 400px;
margin: 400px auto; /*px 代表盒子边距的距离-->*/
border: dashed #58e55e; /*边缘线条样式加颜色*/
padding: 10px; /*内边距距离*/
border-radius: 60px; /*边缘四个角圆角距离*/
/*box-shadow: 0 80px 100px rgba(0, 0, 0, 0.1);*/ /*阴影效果*/
}
.calculator input[type="text"] { /*这是定位的那个显示框*/
width: 100%;
margin-bottom: 30px; /*底部外边距30,给第一行留间距的*/
/*padding: 10px;*/ /*内边距的*/
}
.calculator input[type="button"] { /*数字按键些*/
width: 20%;
padding: 20px;
margin-left: 15px;
margin-bottom: 30px; /*按键大小*/
/*box-sizing: border-box;*/
}

</style>
</head>
<body>

<div class="calculator">
<input type="text" id="display" disabled><!-- disabled 属性表示此输入框不可编辑-->
<input type="button" value="1" οnclick="addToDisplay('1')">
<input type="button" value="2" οnclick="addToDisplay('2')">
<input type="button" value="3" οnclick="addToDisplay('3')">
<input type="button" value="+" οnclick="addToDisplay('+')">
<input type="button" value="4" οnclick="addToDisplay('4')">
<input type="button" value="5" οnclick="addToDisplay('5')">
<input type="button" value="6" οnclick="addToDisplay('6')">
<input type="button" value="-" οnclick="addToDisplay('-')">
<input type="button" value="7" οnclick="addToDisplay('7')">
<input type="button" value="8" οnclick="addToDisplay('8')">
<input type="button" value="9" οnclick="addToDisplay('9')">
<input type="button" value="*" οnclick="addToDisplay('*')">
<input type="button" value="0" οnclick="addToDisplay('0')">
<input type="button" value="C" οnclick="clearDisplay()">
<input type="button" value="=" οnclick="calculate()">
<input type="button" value="/" οnclick="addToDisplay('/')">
</div>

<script>
function addToDisplay(value) { //点击鼠标的时候就会调用方法并且将value值传过来
var displayElement= document.getElementById('display');
var currentValue=displayElement.value
var newValue=currentValue+value;//当点第一次1的时候前两行不起作用,因为框里面没有东西,
当第二次点击的时候,就获取了框内的1和当前点击按钮的value值
displayElement.value=newValue;//这里每次更新框框内按钮的数字包括加减号,显示出来
}

function clearDisplay() {
document.getElementById('display').value = '';
}

function calculate() {
var expression = document.getElementById('display').value;//获取框内的所有字符
var result = eval(expression);//eval内置计算函数 计算上面框内的字符
document.getElementById('display').value = result;

//querySelectorAll,它用于获取文档中匹配指定 CSS 选择器的所有元素,返回的是一个 NodeList 对象。
}
</script>

</body>
</html>

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

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

相关文章

【Linux系统】守护进程

一.进程组&#xff0c;会话 PGID&#xff1a;进程组id&#xff0c;一条命令启动的所有进程及其子进程属于同一个进程组。一条指令中最先创建的进程就是组长&#xff0c;组id就是组长的PID。./启动的SID&#xff1a;会话id&#xff0c;每次登录Linux&#xff0c;操作系统给登录的…

Creating a Pose Control *

为模型设置一个初始的姿势姿态。选择模型的根节点,打开属性编辑器。在选项菜单中选择"ERC Freeze..."。这允许你捕获当前姿势与默认姿势的差异,并将其存储为一个新的参数控制器。为新控制器设置一个唯一的内部名称和显示标签名称。使用属性移动器将新创建的控制器移动…

vue2(4)之scoped解决样式冲突/组件通信/非父子通信/ref和$refs/异步更新/.sync/事件总线/provide和inject

vue2 一、学习目标1.组件的三大组成部分&#xff08;结构/样式/逻辑&#xff09;2.组件通信3.综合案例&#xff1a;小黑记事本&#xff08;组件版&#xff09;4.进阶语法 二、scoped解决样式冲突**1.默认情况**&#xff1a;2.代码演示3.scoped原理4.总结 三、data必须是一个函数…

C语言-调试技巧

目录 一、调试介绍1.1 Debug和Release的介绍1.2 Windows环境调试介绍1.2.1 学会快捷键1.2.2 查看临时变量的值1.2.3 查看内存信息1.2.4 查看调用堆栈1.2.4 查看汇编信息1.2.5 查看寄存器信息 二、编程常见的错误2.1 编译型错误2.2 链接型错误2.3 运行时错误 三、易于调试的代码…

【AI学习】人工智能 or 人造智能 or 人创智能

刚刚读完了《十堂极简人工智能课》这本书&#xff0c;非常精彩的一本书&#xff0c;用非常简短的篇幅&#xff0c;几乎涵盖了人工智能发展的所有重要历程、重要路径和方法、重要观点以及重要问题&#xff0c;将技术以一种哲学思考的方式深入浅出的讲述&#xff0c;实在难得&…

编曲学习:各个段落的架子鼓编写

如何制作出好听又精彩的鼓节奏?【架子鼓编写教学】_哔哩哔哩_bilibili演示软件:Cubase 10.5 演示音源:Superior Drummer 3课件下载:微信公众号“音律屋”, 视频播放量 30743、弹幕量 80、点赞数 1100、投硬币枚数 516、收藏人数 1783、转发人数 131, 视频作者 音律屋, 作者…

Redis---------实现更改数据业务包括缓存更新,缓存穿透雪崩击穿的处理

三种更新策略 内存淘汰是Redis内存的自动操作&#xff0c;当内存快满了就会触发内存淘汰。超时剔除则是在存储Redis时加上其有限期(expire)&#xff0c;有限期一过就会自动删除掉。而主动更新则是自己编写代码去保持更新&#xff0c;所以接下来研究主动更新策略。 主动更新策略…

配置 Trunk,实现相同VLAN的跨交换机通信

1.实验环境 公司的员工人数已达到 100 人&#xff0c;其网络设备如图所示。现在的网络环境导致广播较多网速慢&#xff0c;并且也不安全。公司希望按照部门划分网络&#xff0c;并且能够保证一定的网络安全性。 其网络规划如下。 PC1和 PC3为财务部&#xff0c;属于VLAN 2&…

npm详解:Node.js包管理器的奥秘

&#x1f90d; 前端开发工程师、技术日更博主、已过CET6 &#x1f368; 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 &#x1f560; 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 &#x1f35a; 蓝桥云课签约作者、上架课程《Vue.js 和 E…

Ubuntu系统安装nvfortran详细步骤【笔记】

实践设备&#xff1a;华硕FX-PRO&#xff08;NVIDIA GeForce GTX 960M&#xff09; Ubuntu系统安装NVFORTRAN&#xff08;NVIDIA Fortran Compiler&#xff09;步骤如下&#xff1a; 安装依赖项&#xff1a;在安装NVFORTRAN之前&#xff0c;你需要确保系统已经安装了一些必要…

MyBatis-plus笔记——条件构造器和常用接口

wapper介绍 Wapper&#xff1a;条件构造抽象类 AbstractWapper&#xff1a;用于查询条件封装&#xff0c;生成 sql 的 where 条件 QueryWrapper&#xff1a;查询条件封装UpdateWrapper&#xff1a;Update 条件封装AbstractLambdaWrapper&#xff1a;使用Lambda语法 LambdaQuery…

IDEA启动项目报错:Error running ‘‘: Command line is too long.

1、在workspace.xml 2、 在标签 <component name"PropertiesComponent"> 添加 <property name"dynamic.classpath" value"true" />

golang:atomic.Pointer

1.atomic.Pointer atomic.Pointer 是 Go 语言标准库 sync/atomic 提供的一种原子指针类型。它用于在并发环境中对指针进行原子操作&#xff0c;以确保线程安全性。 什么是原子操作&#xff1f;golang 的原子操作 在多线程编程中&#xff0c;当多个线程同时访问和修改同一个…

天地图路径规划功能实现

目录 1、天地图路径规划2、路径规划3、参数说明4、Demo 1、天地图路径规划 天地图Web服务API为用户提供HTTP/HTTPS接口&#xff0c;即开发者可以通过这些接口使用各类型的地理信息数据服务&#xff0c;可以基于此开发跨平台的地理信息应用。 Web服务API对所有用户开放。使用本…

全栈开发之路——前端篇(3)setup和响应式数据

全栈开发一条龙——前端篇 第一篇&#xff1a;框架确定、ide设置与项目创建 第二篇&#xff1a;介绍项目文件意义、组件结构与导入以及setup的引入。 本文为该系列的第三篇&#xff0c;主要讲述Vue核心的setup语法&#xff0c;同时讲解再使用了setup后如何设置响应式数据。 辅助…

Linux专栏05:Linux基本指令之目录处理指令

博客主页&#xff1a;Duck Bro 博客主页系列专栏&#xff1a;Linux专栏关注博主&#xff0c;后期持续更新系列文章如果有错误感谢请大家批评指出&#xff0c;及时修改感谢大家点赞&#x1f44d;收藏⭐评论✍ Linux基本指令之目录处理指令 编号&#xff1a;05 文章目录 Linux基…

设置UIProgressView的样式

UIProgressView是UIKit框架中的一个控件&#xff0c;用于显示任务的完成进度。你可以使用UIProgressView来展示任务的完成情况&#xff0c;例如下载文件、上传数据等。 要设置UIProgressView的样式&#xff0c;包括粗细、颜色等&#xff0c;你可以使用UIProgressView的一些属性…

在springboot项目中实现将上传的jpg图片类型转为pdf并保存到本地

前言&#xff1a;前端使用uniapp中的uni.canvasToTempFilePath方法将画板中的内容保存为jpg上传至后端处理 uni.canvasToTempFilePath({canvasId: firstCanvas,sourceType: [album],fileType: "jpg",success: function (res1) {let signature_base64 res1.tempFile…

发表博客之:weight only int8 详细讲解,小白都可以看得懂,不懂请来打我!

发表博客之&#xff1a;weight only int8 详细讲解&#xff0c;小白都可以看得懂&#xff0c;不懂请来打我&#xff01; 考虑一个模型中有一个Gemm Op&#xff0c;有两个输入&#xff0c;假设都是fp16数据类型吧&#xff01; input0是 [ M , K ] [M,K] [M,K],input1是 [ K , N…

Linux的基础IO:文件描述符 重定向本质

目录 前言 文件操作的系统调用接口 open函数 close函数 write函数 read函数 注意事项 文件描述符-fd 小补充 重定向 文件描述符的分配原则 系统调用接口-dup2 缓冲区 缓冲区的刷新策略 对于“2”的理解 小补充 前言 在Linux中一切皆文件&#xff0c;打开文件…