JS实现计算器功能

8 篇文章 3 订阅

点击即可进入计算器页面

点击即可进入计算器页面

代码

代码:

<!DOCTYPE html>
<html>
	<head lang="en">
		<meta charset="UTF-8">
		<title></title>
		<!-- 样式 -->
		<style>
			tr,td{
				text-align: center;
			}
			a{
				/* 去除下划线 */
				text-decoration: none;
				color: black;
			}
			a:hover{
				background-color:darkgray;
			}
		</style>
	</head>
	<body>
		<!-- 表格 -->
		<table border="1px" cellpadding="1" cellspacing="1" align="center">
			<tr>
				<td colspan="4" style="font-weight: 600;">计算器</td>
			</tr>
			<tr>
				<td colspan="4">
					<input type="text" id="numInput" style="text-align: right;"/>
				</td>
			</tr>
			<tr>
				<td onclick="onClick(this)"><a href="#">C</a></td>
				<td onclick="onClick(this)"><a href="#">/</a></td>
				<td onclick="onClick(this)"><a href="#">*</a></td>
				<td onclick="onClick(this)"><a href="#">-</a></td>
			</tr>
			<tr>
				<td onclick="onClick(this)"><a href="#">7</a></td>
				<td onclick="onClick(this)"><a href="#">8</a></td>
				<td onclick="onClick(this)"><a href="#">9</a></td>
				<td onclick="onClick(this)" rowspan="2"><a href="#">+</a></td>
			</tr>
			<tr>
				<td onclick="onClick(this)"><a href="#">4</a></td>
				<td onclick="onClick(this)"><a href="#">5</a></td>
				<td onclick="onClick(this)"><a href="#">6</a></td>
			</tr>
			<tr>
				<td onclick="onClick(this)"><a href="#">1</a></td>
				<td onclick="onClick(this)"><a href="#">2</a></td>
				<td onclick="onClick(this)"><a href="#">3</a></td>
				<td onclick="onClick(this)" rowspan="2"><a href="#">=</a></td>
			</tr>
			<tr>
				<td onclick="onClick(this)"><a href="#">0</a></td>
				<td onclick="onClick(this)" colspan="2"><a href="#">.</a></td>
			</tr>
		</table>
		
		<script>
			var strs = "";
			function onClick(count) {
				var numInput = document.getElementById("numInput");
				// 接收显示
				var str = count.innerText;
				// 如果等于(点击)C就清空
				if(str == "C"){
					numInput.value = "";
					str = "";
					strs = "";
				}
				// 如果等于(点击)= 执行eval()算法 得到结果
				if(str == "="){
					str = eval(strs);
					numInput.value = "";
					strs = str + "";
				}else{
					// 否则继续将内容写入字符串后
					strs += str;
				}
				// 如果等于(点击) + - * / 就显示 + - * /
				if(str == "+" || str == "-" || str == "*" || str == "/"){
					numInput.value = str;
				}else{
					// 如果第一次不是(没点击)数字 将此内容(运算符)清除
					if(isNaN(numInput.value)){
						numInput.value = "";
					}
					// 如果一直是数字则继续将内容写入字符串后
					numInput.value += str;
				}
			}
		</script>
	</body>
</html>

效果

样式效果图:

在这里插入图片描述
运行效果图:

在这里插入图片描述
在这里插入图片描述

联系博主

博主QQ:2425991616

博主微信:2425991616

博主邮箱:aboutgjc@outlook.com

扫码即可添加博主微信

博主微信

扫码即可添加博主QQ

博主QQ

打赏博主

在这里插入图片描述
在这里插入图片描述

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

是阿超

现在二师兄的肉比师父的都贵了.

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值