用script实现的一个简易计算机

news2024/9/27 21:30:11

目录

一、计算器原理

二、源码

三、结果展示

四、不足与改进


一、计算器原理

首先我们列出想象中简易计算器的样子:

虽然画的磕碜但是应该不影响下面的操作hh

首先想到用表格形式在网页中表示它,是一个5行4列的表格,接着要实现计算器的功能,每个按钮都需要添加事件--->onclick()当鼠标点击时触发, 所有的数字和运算符都要使用onclick触发,等于号和c(清空键)较为特殊,他们需要对应与数字和普通运算符不同的事件:计算结果和清空输入。以及最上方的显示块需要时刻与输入的内容对应也是不同的事件

运算的过程较为简单,只使用了eval()函数进行计算。

最后就是对计算器输入过程的修饰,计算过程不能出现数字后跟多个运算符的情况,如5++或5+-*/,这样会导致eval()函数无法正常计算,所以需要对输入时的事件进行休整。

二、源码

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<style>
			table {
				border: 10px;
				margin: auto;
			}

			td {
				border: 2px solid black; //单元格边框
				text-align: center;
				/*单元格内容居中*/
				padding: 20px;
				/*内边距*/
			}
		</style>
	</head>
	<body>
		<table>
			<tr>
				<td colspan="4" id="result"></td>
			</tr>
			<tr>
				<td onclick="appendresult('7')">7</td>
				<td onclick="appendresult('8')">8</td>
				<td onclick="appendresult('9')">9</td>
				<td onclick="appendresult('+')">+</td>
			</tr>
			<tr>
				<td onclick="appendresult('4')">4</td>
				<td onclick="appendresult('5')">5</td>
				<td onclick="appendresult('6')">6</td>
				<td onclick="appendresult('-')">-</td>
			</tr>
			<tr>
				<td onclick="appendresult('1')">1</td>
				<td onclick="appendresult('2')">2</td>
				<td onclick="appendresult('3')">3</td>
				<td onclick="appendresult('*')">*</td>
			</tr>
			<tr>
				<td onclick="appendresult('0')">0</td>
				<td id="clear" onclick="clearall()">c</td>
				<td onclick="caculate()">=</td>
				<td onclick="appendresult('/')">/</td>
			</tr>
		</table>
	</body>
	<script>
		var inputment = ""; //输入的内容
		function appendresult(value) {
			// 判断value是数字还是符号
			if (value == "+" || value == "-" || value == "*" || value == "/") {
				// 检查最后一个字符是否为运算符
				if (inputment.length > 0 && (inputment[inputment.length - 1] == "+" ||
						inputment[inputment.length - 1] == "-" ||
						inputment[inputment.length - 1] == "*" ||
						inputment[inputment.length - 1] == "/")) {
					return; // 如果是运算符,则不添加新的运算符,return不进行任何操作
				}
				inputment += value; // 添加新的运算符
			} else {
				// 如果是数字,直接添加
				inputment += value;
			}

			update();
		}

		function caculate() {
			var result = eval(inputment);
			inputment = result.toString(); //更新全局变量
			update();
		}

		function update() {
			document.getElementById("result").innerText = inputment || "0";
		}

		function clearall() {
			document.getElementById("result").innerText = "";
			inputment = "";
		}
	</script>
</html>

三、结果展示

 

可以看到不会出现多个运算符重复出现的错误。

四、不足与改进

在制作此计算器时,用的是表格来表示计算器,没有考虑到点击形式的问题,使得在使用时鼠标全程是I的状态,不是点击状态,用起来十分别扭,除了将整个表格变成<input>中的按钮状态外,有更便捷的方法来解决:

可以在td的类选择器中添加

cursor: pointer; /* 鼠标悬停时显示手型光标 */

为了使用时更加便捷,还可以使用伪类添加鼠标悬停时的背景色以及点击时的背景色:

td:hover { background-color: #f0f0f0; /* 鼠标悬停时的背景色 */ }

td:active { background-color: #d0d0d0; /* 点击时的背景色 */ } 

 最后的效果:

此时的鼠标放在了数字7上,并且是点击态,再点击后颜色会加深一点。

改进后的代码:

 

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8" />
		<title></title>
		<style>
			table {
				border: 10px;
				margin: auto;
			}

			td {
				border: 2px solid black; //单元格边框
				text-align: center;
				/*单元格内容居中*/
				padding: 20px;
				/*内边距*/
				cursor: pointer;
				/* 鼠标悬停时显示手型光标 */
			}

			td:hover {
				background-color: #f0f0f0;
				/* 鼠标悬停时的背景色 */
			}

			td:active {
				background-color: #d0d0d0;
				/* 点击时的背景色 */
			}
		</style>
	</head>
	<body>
		<table>
			<tr>
				<td colspan="4" id="result"></td>
			</tr>
			<tr>
				<td onclick="appendresult('7')">7</td>
				<td onclick="appendresult('8')">8</td>
				<td onclick="appendresult('9')">9</td>
				<td onclick="appendresult('+')">+</td>
			</tr>
			<tr>
				<td onclick="appendresult('4')">4</td>
				<td onclick="appendresult('5')">5</td>
				<td onclick="appendresult('6')">6</td>
				<td onclick="appendresult('-')">-</td>
			</tr>
			<tr>
				<td onclick="appendresult('1')">1</td>
				<td onclick="appendresult('2')">2</td>
				<td onclick="appendresult('3')">3</td>
				<td onclick="appendresult('*')">*</td>
			</tr>
			<tr>
				<td onclick="appendresult('0')">0</td>
				<td id="clear" onclick="clearall()">c</td>
				<td onclick="caculate()">=</td>
				<td onclick="appendresult('/')">/</td>
			</tr>
		</table>
	</body>
	<script>
		var inputment = ""; //输入的内容
		function appendresult(value) {
			// 判断value是数字还是符号
			if (value == "+" || value == "-" || value == "*" || value == "/") {
				// 检查最后一个字符是否为运算符
				if (inputment.length > 0 && (inputment[inputment.length - 1] == "+" ||
						inputment[inputment.length - 1] == "-" ||
						inputment[inputment.length - 1] == "*" ||
						inputment[inputment.length - 1] == "/")) {
					return; // 如果是运算符,则不添加新的运算符,return不进行任何操作
				}
				inputment += value; // 添加新的运算符
			} else {
				// 如果是数字,直接添加
				inputment += value;
			}

			update();
		}

		function caculate() {
			var result = eval(inputment);
			inputment = result.toString(); //更新全局变量
			update();
		}

		function update() {
			document.getElementById("result").innerText = inputment || "0";
		}

		function clearall() {
			document.getElementById("result").innerText = "";
			inputment = "";
		}
	</script>
</html>

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

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

相关文章

ShardingSphere中的ShardingJDBC常见分片算法的实现

文章目录 ShardingJDBC快速入门修改雪花算法和分表策略核心概念分片算法简单INLINE分片算法STANDARD标准分片算法COMPLEX_INLINE复杂分片算法CLASS_BASED自定义分片算法HINT_INLINE强制分片算法 注意事项 ShardingJDBC Git地址 快速入门 现在我存在两个数据库&#xff0c;并…

【传知代码】Flan-T5 使用指南(论文复现)

当今&#xff0c;自然语言处理技术正在以前所未有的速度和精度发展。在这个领域中&#xff0c;Flan-T5作为一种新兴的预训练语言模型&#xff0c;正吸引着广泛的关注和应用。Flan-T5不仅仅是一个强大的文本生成工具&#xff0c;它还能通过提供高效的语义理解和多任务学习能力&a…

【java计算机毕设】智慧校园管理系统MySQL springboot vue HTML maven寒暑假小组设计项目源码作业带文档安装环境

目录 1项目功能 2项目介绍 3项目地址 1项目功能 【java计算机毕设】智慧校园管理系统MySQL springboot vue HTML maven寒暑假小组设计项目源码作业带文档安装环境 2项目介绍 系统功能&#xff1a; 智慧校园管理系统包括管理员、用户、老师三种角色。 管理员功能包括个人中心…

【2024最新华为OD-C/D卷试题汇总】[支持在线评测] 团队关系判定(100分) - 三语言AC题解(Python/Java/Cpp)

🍭 大家好这里是清隆学长 ,一枚热爱算法的程序员 ✨ 本系列打算持续跟新华为OD-C/D卷的三语言AC题解 💻 ACM金牌🏅️团队| 多次AK大厂笔试 | 编程一对一辅导 👏 感谢大家的订阅➕ 和 喜欢💗 🍿 最新华为OD机试D卷目录,全、新、准,题目覆盖率达 95% 以上,支持题…

大语言模型学习笔记 LangChain简述

一、简述 LangChain是一个由大型语言模型 (LLM) 驱动的应用程序开发框架。LangChain 旨在为开发人员提供一系列功能&#xff0c;利用大型语言模型简化应用程序的创建和管理。 LangChain 可充当几乎所有 LLM 的通用接口&#xff0c;提供集中式开发环境来构建 LLM 应用程序并将其…

二十天刷leetcode【hot100】算法- day1[前端Typescript]

哈希表 1. 两数之和 给定一个整数数组 nums 和一个整数目标值 target&#xff0c;请你在该数组中找出 和为目标值 target 的那 两个 整数&#xff0c;并返回它们的数组下标。 你可以假设每种输入只会对应一个答案。但是&#xff0c;数组中同一个元素在答案里不能重复出现。你…

适用于个人使用的十大数据恢复工具:综合指南

有许多数据恢复工具和软件可用于帮助恢复丢失或损坏的文件。通过了解您的需求并考虑这里探讨的工具&#xff0c;您将能够选择最佳的数据恢复软件&#xff0c;并希望找回您丢失的宝藏。在本综合指南中&#xff0c;我们将探索个人使用的十大数据恢复工具&#xff0c;重点介绍它们…

ESP32人脸识别开发- 基础介绍(一)

一、ESP32人脸识别的方案介绍 目前ESP32和ESP32S3都是支持的&#xff0c;官方推的开发板有两种&#xff0c;一种 ESP-EYE ,没有LCD 另一种是ESP32S3-EYE,有带LCD屏 二、ESP32人脸识别选用ESP32的优势 ESP32S3带AI 加速功能&#xff0c;在人脸识别的速度是比ESP32快了不少 | S…

鸿蒙 IM 即时通讯开发实践,融云 IM HarmonyOS NEXT 版

融云完成针对“纯血鸿蒙”操作系统的 SDK 研发&#xff0c;HarmonyOS NEXT 版融云 IM SDK 已上线&#xff0c;开发者可在“鸿蒙生态伙伴 SDK 市场”查询使用。 发挥 20 年通信行业技术积累和领创品牌效应&#xff0c;融云为社交、娱乐、游戏、电商、出行、医疗等各行业提供专业…

【深澜计费管理系统存在任意文件读取漏洞复现和检测脚本】

目录 一、漏洞介绍 二、poc利用 三、批量检测脚本 一、漏洞介绍 深澜计费管理系统存在任意文件读取漏洞。攻击者可以利用这个漏洞读取服务器上的任何文件,包括配置文件、源代码文件和敏感数据等。 二、poc利用 360 quake&#xff1a; favicon: "1fc27943c1f0d9b54cc…

modin,一个强大的 Python 库!

更多资料获取 &#x1f4da; 个人网站&#xff1a;ipengtao.com 大家好&#xff0c;今天为大家分享一个强大的 Python 库 - modin。 Github地址&#xff1a;https://github.com/modin-project/modin 在数据科学和机器学习的领域中&#xff0c;Pandas 是一个非常流行的数据处理…

Excel第33享:借助易用宝将多个表格合并到一个表格

1、需求描述 现有3个销售数据的Excel表格&#xff0c;希望将其整合到一个表格里&#xff0c;如下图所示。 2、具体操作 &#xff08;1&#xff09;下载一个插件“易用宝”。 下载地址&#xff1a;最新版下载 | Excel易用宝 如果本地址失效&#xff0c;可以直接百度搜索“易…

2024年企业电脑加密系统排名|电脑加密系统TOP8

随着信息技术的发展&#xff0c;数据安全变得尤为重要。企业需要可靠的加密系统来保护敏感信息不受内部或外部威胁。以下是我为您推荐的8款企业电脑加密系统&#xff0c;都是知名的产品。 1.安企神系统 简介&#xff1a;安企神是一款专注于企业数据安全管理的综合性软件&#…

你的网站访客来自何方?GoAccess地理分析工具告诉你!

你的网站访客来自何方?GoAccess地理分析工具告诉你! 致读者: 点击上方 “雪之梦技术驿站” → 点击右上角“ … ”→ 点选“设为星标★ ” 加上星标,就不会找不到我啦!想象一下,你站在世界地图前,手中的放大镜缓缓移动,寻找着那些隐藏在数字海洋中的神秘岛屿——IP地址…

下一个十年能否赚到钱,就看你消化得了这篇文章不

所有的互联网创业者在2024年都会迎来前所未有的挑战&#xff0c;因为中国经济正在发生翻天覆地的变化&#xff0c;人口红利的消失&#xff0c;流量红利的消失&#xff0c;也就是说我们从一个增量时代到存量时代的过渡中&#xff0c;所以这两年我们可以清晰的看到很多传统老板正…

【传知代码】一款轻量级的隐私保护推荐系统(论文复现)

在当今信息爆炸的时代&#xff0c;个性化推荐系统在我们的日常生活中扮演着越来越重要的角色。然而&#xff0c;随着个人数据的广泛收集和利用&#xff0c;隐私保护成为了一个不可忽视的挑战。为了平衡推荐系统的效用与用户隐私的保护&#xff0c;一款轻量级的隐私保护推荐系统…

装win7出现0x0000007b蓝屏原因分析及解决方法

最近有网友问我装win7出现0x0000007b蓝屏怎么办&#xff1f;0x0000007b电脑蓝屏通常情况是硬盘的存储控制器驱动加载错误导致故障。出现0x0000007b蓝屏代码的原因有很多比如硬盘模式、安装的系统没有集成相关的磁盘控制器驱动等&#xff0c;下面小编就教大家装win7出现0x000000…

VFS(虚拟文件系统)是什么,有真实的文件系统吗?

文章目录 1 VFS&#xff08;虚拟文件系统&#xff09;是什么1.1 VFS 的设计目的 2 VFS 的工作原理2.1 VFS 的文件操作流程 3 真实的文件系统3.1 常见的真实文件系统3.2 真实文件系统与 VFS 的关系 4 总结封面 1 VFS&#xff08;虚拟文件系统&#xff09;是什么 虚拟文件系统&a…

水论文如何找创新,优秀者模仿,末尾有例子示范_来自B站水论文的程序猿

系列文章目录 文章目录 系列文章目录一、水论文如何找创新关键在“找”1、相似领域找2、找到后3、如何稍微改动4、 自己领域找 二、示例 一、水论文如何找创新关键在“找” 1、相似领域找 比如某人研究视频描述中的单句视频描述&#xff0c;他可以去密集视频描述领域找相关论…

springMVC中从Excel文件中导入导出数据

目录 1. 数据库展示2. 导入依赖3. 写方法3.1 导入数据3.2 导出数据 4. 效果5. 不足6. 参考链接 1. 数据库展示 2. 导入依赖 pom.xml <!--文件上传处理--><dependency><groupId>commons-io</groupId><artifactId>commons-io</artifactId>&…