JavaScript实例--实现计算器
作者:程序员云锦? 发布时间:2024-04-23 09:26:17
标签:JavaScript,实现,计算器
一、实例代码
HTML:
<!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>Document</title>
<style>
/* Basic Reset */
</style>
</head>
<body>
<div class="center">
<h1>计算器</h1>
<a href="https://github.com/guuibayer/simple-calculator" rel="external nofollow" target="_blank"><i class="fa fa-github"></i></a>
<form name="calculator">
<input type="button" id="clear" class="btn other" value="C">
<input type="text" id="display">
<br>
<input type="button" class="btn number" value="7" onclick="get(this.value);">
<input type="button" class="btn number" value="8" onclick="get(this.value);">
<input type="button" class="btn number" value="9" onclick="get(this.value);">
<input type="button" class="btn operator" value="+" onclick="get(this.value);">
<br>
<input type="button" class="btn number" value="4" onclick="get(this.value);">
<input type="button" class="btn number" value="5" onclick="get(this.value);">
<input type="button" class="btn number" value="6" onclick="get(this.value);">
<input type="button" class="btn operator" value="*" onclick="get(this.value);">
<br>
<input type="button" class="btn number" value="1" onclick="get(this.value);">
<input type="button" class="btn number" value="2" onclick="get(this.value);">
<input type="button" class="btn number" value="3" onclick="get(this.value);">
<input type="button" class="btn operator" value="-" onclick="get(this.value);">
<br>
<input type="button" class="btn number" value="0" onclick="get(this.value);">
<input type="button" class="btn operator" value="." onclick="get(this.value);">
<input type="button" class="btn operator" value="/" onclick="get(this.value);">
<input type="button" class="btn other" value="=" onclick="calculates();">
</form>
</div>
<script>
</script>
</body>
</html>
CSS:
* {
border: none;/*去除默认边框*/
font-family: 'Open Sans', sans-serif;/*更改字体*/
margin: 0;/*去除默认外边距*/
padding: 0;/*去除默认内边距*/
}
.center {
background-color: #fff;
border-radius: 50%;/*圆角*/
height: 600px;/*计算器总高度*/
margin: auto;/*水平居中*/
width: 600px;/*宽度*/
}
h1 {/*修改标题样式*/
color: #495678;/*字体颜色*/
font-size: 30px; /*字体大小*/
margin-top: 20px;/*顶部外边距*/
padding-top: 50px;/*顶部内边距*/
display: block;/*修改为块级元素,独占一行*/
text-align: center;/*文字居中*/
text-decoration: none;/*去除默认文字样式*/
}
a {/*这是标题下面一块位置,点击可以跳转到github的仓库地址*/
color: #495678;
font-size: 30px;
display: block;
text-align: center;
text-decoration: none;
padding-top: 20px;
}
form {/*定义表单区域的样式*/
background-color: #495678;/*背景颜色*/
box-shadow: 4px 4px #3d4a65;/*阴影*/
margin: 40px auto;/*定义外边距*/
padding: 40px 0 30px 40px; /*定义内边距*/
width: 280px;/*宽度*/
/*高度由内容撑起*/
}
.btn {/*定义每个数字按钮的格式*/
outline: none;/*清除默认边框样式*/
cursor: pointer;/*定义鼠标移上时变成手的图案,使用户知道可点击*/
font-size: 20px;/*字体大小*/
height: 45px;/*按钮高度*/
margin: 5px 0 5px 10px;/*外边距*/
width: 45px;/*按钮宽度*/
}
.btn:first-child {
margin: 5px 0 5px 10px;/*第一个按钮特殊*/
}
.btn, #display, form {/*按钮,文本输入框和整个表单区域*/
border-radius: 25px;/*圆角*/
}
/*定义输入框*/
#display {
outline: none;/*清除默认边框样式*/
background-color: #98d1dc;/*背景颜色*/
box-shadow: inset 6px 6px 0px #3facc0;/*阴影*/
color: #dededc;/*内部文本颜色*/
font-size: 20px;/*文本大小*/
height: 47px;/*输入框高度*/
text-align: right;/*文本右对齐*/
width: 165px;/*定义宽度*/
padding-right: 10px;/*右内边距*/
margin-left: 10px;/*左外边距*/
}
.number {/*定义数字的按钮*/
background-color: #72778b;/*背景颜色*/
box-shadow: 0 5px #5f6680;/*阴影*/
color: #dededc;/*数字颜色*/
}
.number:active {/*选中数字样式,就是点击数字的动态效果*/
box-shadow: 0 2px #5f6680;
-webkit-transform: translateY(2px);
-ms-transform: translateY(2px);
-moz-tranform: translateY(2px);
transform: translateY(2px);
/*这四个其实是一样的,这是为了兼容不同的浏览器,效果就是向上移动2px距离
需要配合js,点击时赋active,点击后抹掉
*/
}
.operator {/*定义运算符按钮*/
background-color: #dededc;/*背景颜色*/
box-shadow: 0 5px #bebebe;/*阴影*/
color: #72778b;/*运算符颜色*/
}
.operator:active {/*定义运算符点击时*/
/*这个比数字点击多了一个,就是把下面的阴影减少了一点*/
box-shadow: 0 2px #bebebe;
-webkit-transform: translateY(2px);
-ms-transform: translateY(2px);
-moz-tranform: translateY(2px);
transform: translateY(2px);
}
.other {/*定义归零键和=键*/
background-color: #e3844c;/*背景颜色*/
box-shadow: 0 5px #e76a3d;/*阴影*/
color: #dededc;/*符号颜色*/
}
.other:active {/*点击效果和点击运算符一样*/
box-shadow: 0 2px #e76a3d;
-webkit-transform: translateY(2px);
-ms-transform: translateY(2px);
-moz-tranform: translateY(2px);
transform: translateY(2px);
}
JavaScript:
/* limpa o display */
document.getElementById("clear").addEventListener("click", function() {
document.getElementById("display").value = "";
});
/* recebe os valores */
function get(value) {
document.getElementById("display").value += value;
}
/* calcula */
function calculates() {
var result = 0;
result = document.getElementById("display").value;
document.getElementById("display").value = "";
document.getElementById("display").value = eval(result);
};
二、实例演示
页面加载后,显示一个计算器的页面,可以进行正常的四则运算
运算结果:
也可以归零,加小数等等操作
三、实例剖析
方法解析
document.getElementById("display").value = eval(result);
eval()
函数计算 JavaScript
字符串,并把它作为脚本代码来执行。
如果参数是一个表达式,eval() 函数将执行表达式。如果参数是Javascript
语句,eval()将执行 Javascript 语句。
实例执行原理解析:
document.getElementById("clear").addEventListener("click", function() {
document.getElementById("display").value = "";
});
监听归零键的click操作,点击则归零键则执行代码把display
输入框清空
function get(value) {
document.getElementById("display").value += value;
}
每个键上onclick
属性绑定函数get()
,点击相应键则把相应键的值添加到display
输入框中,直接做字符串的追加
function calculates() {
var result = 0;
result = document.getElementById("display").value;
document.getElementById("display").value = "";
document.getElementById("display").value = eval(result);
};
核心计算函数,首先获取输入框display
的字符串,然后清空输入框,调用eval()函数计算表达式的值后再赋给输入框display,实现计算器的简易功能
来源:https://blog.csdn.net/m0_61607810/article/details/121392451


猜你喜欢
- Python Assert 为何不尽如人意?Python中的断言用起来非常简单,你可以在assert后面跟上任意判断条件,如果断言失败则会抛
- Page Object模式是Selenium中的一种测试设计模式,主要是将每一个页面设计为一个Class,其中包含页面中需要测
- 近段时间由于修改一个ASP程序(有SQL注入漏洞),在网上找了很多相关的一些防范办法,都不近人意,所以我将现在网上的一些方法综合改良了一下,
- 在python中安装了lxml-4.2.1,在使用时发现导入etree时IDE中报错Unresolved reference其实发现,不影响
- 基于 SpringBoot与SpringSecurity整合 案例的修改:数据库 user 表注,密码是由 BCrypt 算法加密对应用户名
- 1.ACCESS查询(query_info):select * from info where stu = name1 and age =
- 我们现在回到函数上。记得我们用 SUM 这个指令来算出所有的 Sales (营业额)吧!如果我们的需求变成是要算出每一间店 (store_n
- 有个需求需要把markdown转成html模块,查询了一下刚好有这个模块安装 pip install amrkdown安装完成直接转换并保存
- 本文实例为大家分享了用简单的神经网络来训练和测试的具体代码,供大家参考,具体内容如下刚开始学习tf时,我们从简单的地方开始。卷积神经网络(C
- 如题:我写入关键字到数据库,多的时候用|隔开了,我提取再做相关文章搜索的时候,我怎么提取用|隔开的文字啊,这样我就好用关键字做搜索啊 回复:
- 本文实例讲述了Go语言单链表实现方法。分享给大家供大家参考。具体如下:1. singlechain.go代码如下:////////////单
- 方法组成模式方法里的所有语句都必须处在同一个归纳层次上无用的注释让代码自我表白标注为什么这样,而不是如何这样对方法表现进行描述等于重复表现这
- QQ医生在广大用户心中一直以来都是清爽便捷的一款安全工具,随着QQ医生的不断发展,QQ医生团队一直在思考,怎样能够给QQ医生用户带来性能更优
- 当很多人发现在DW4中定义CSS很方便的时候,开始报怨FP2000不能定义CSS,甚至就此抨击FP2000如何的不好。事实上,在FP2000
- 开局一张图:可以看出,在项目部署后,我们的资源文件请求都会保持原本大小,如果文件过大,并且很多的情况下,会导致网络请求耗时,严重点可能阻塞后
- 本文实例为大家分享了python3.6实现弹跳小球游戏的具体代码,供大家参考,具体内容如下import randomimport timef
- 中文乱码问题当我第一次接触mysql,首先让我难受的是mysql的乱码问题,百度上也有许多有关的解决方案,不过作为亲身受害者,我想很有必要贴
- 当我们使用访问一个没有声明的变量时,JS会报错;而当我们给一个没有声明的变量赋值时,JS不会报错误,相反它会认为我们是要隐式申明一个全局变量
- 抽取出我们代码中共性的东西是一个很好的编程习惯。 比如,像以下的两个Python函数:def say_hello(person_name):
- 1.格式化输出 chop 是rtrim()的别名;ltrim() trim()nl2br()将\n转换成<br>print,ec