JavaScript+HTML,简单的计算器实现
成功进化到程序猿快一年多了, 还没写过计算器, 正好今天比较闲,随手写了个计算器,最简单的实现,核心是eval()方法,把字符串作为JS代码处理,把输入的信息拼接成字符串,点等号执行代码得到结果,出异常弹窗提示
只用了几十行JS代码,感觉还可以精简 , 我是一只追求简洁的程序猿
@author beiguapipi 1//存储算式
var all="";
//添加字符串到式子
function add(obj){
if(document.getElementById("jieguo").innerHTML){
window.location.reload();
}else{
all = all+obj.value;
document.getElementById("jisuan").innerHTML=all;
}
}
//删除一个最后的字符
function del(){
if(all.length>0){
all= all.substr(0 ,all.length-1)
document.getElementById("jisuan").innerHTML=all;
}
}
//计算
function jisuan(){
try{
//将字符串作为JS代码处理
var num = eval(all);
if(isNaN(num)){
//如果出异常了,新建异常信息
var e = new Error();
e.message="输入式子不合法";
throw e;
}else{
if(num=="Infinity"||num=="-Infinity"){
alert("运算中分母不能为零")
window.location.reload();
}else{
document.getElementById("jieguo").innerHTML=num;
}
}
}catch(e){
//输出异常信息,刷新页面
alert(e)
window.location.reload();
}
}
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>简单计算器</title>
<link type="text/css" rel="stylesheet" href="css.css">
<script type="text/javascript" src="control.js" charset="utf-8"></script>
</head>
<body>
<div id="body">
<div id="title">
<span id="sp">简单计算器</span>
</div>
<div id="area">
<div id="top">
<span id="jisuan"></span>
</div>
<div id="mid">
计算结果:<span id="jieguo"></span>
</div>
<div id="button">
<br>
<input onclick="reflush()" id="clear" class="but" type="button" value="清空">
<input onclick="del()" id="del" class="but" type="button" value="退格">
<input onclick="add(this)" class="but" type="button" value="/">
<input onclick="add(this)" class="but" type="button" value="*"><br><br>
<input onclick="add(this)" class="but" type="button" value="1">
<input onclick="add(this)" class="but" type="button" value="2">
<input onclick="add(this)" class="but" type="button" value="3">
<input onclick="add(this)" class="but" type="button" value="-"><br><br>
<input onclick="add(this)" class="but" type="button" value="4">
<input onclick="add(this)" class="but" type="button" value="5">
<input onclick="add(this)" class="but" type="button" value="6">
<input onclick="add(this)" class="but" type="button" value="+"><br><br>
<input onclick="add(this)" class="but" type="button" value="7">
<input onclick="add(this)" class="but" type="button" value="8">
<input onclick="add(this)" class="but" type="button" value="9"><br><br>
<input onclick="add(this)" id="num_0" class="but" type="button" value="0">
<input onclick="add(this)" class="but" type="button" value="."><br>
<input onclick="jisuan()" id="num_deng" class="but" type="button" value="=">
<input onclick="add(this)" class="but" type="button" value="(">
<input onclick="add(this)" class="but" type="button" value=")">
</div>
</div>
</div>
</body>
</html>
CSS代码
@CHARSET "UTF-8";@CHARSET "UTF-8";
*{
margin: 0px;
padding: 0px;
}
#body{
margin: auto;
margin-top:10px;
width: 450px;
height: 600px;
border: solid 5px rgb(241,241,241);
background:rgb(255,255,225);
}
#title{
width: 400px;
height: 50px;
position: relative;
left:25%;
}
#sp{
font-size: 1cm;
font-style: oblique;
}
#area{
width: 450px;
height: 550px;
border: solid 1px rgb(0,115,0);
float: left;
}
#top{
width: 400px;
height: 35px;
border: solid 3px rgb(200,225,225);
float: left;
position: relative;
left:20px;
top:15px;
font-size: 25px;
background-color: rgb(255,255,255)
}
#jisuan{
float: right;
}
#mid{
width: 400px;
height: 35px;
border: solid 3px rgb(200,225,225);
float: left;
position: relative;
left:20px;
top:30px;
font-size: 25px;
background-color: rgb(255,255,255)
}
#jieguo{
width: 270px;
height: 35px;
border: solid 1px rgb(200,225,225);
float: right;
}
#button{
width: 400px;
height: 400px;
border: solid 3px rgb(200,225,225);
float: left;
position: relative;
left:20px;
top:50px;
}
.but{
width: 90px;
height: 45px;
position: relative;
left:10px;
}
#num_0{
width: 187px;
}
#num_deng{
height: 108px;
position: relative;
left:302px;
top:-108px;
}
input{
font-size: 25px;
}
JavaScript+HTML,简单的计算器实现的更多相关文章
- 用JavaScript制作简单的计算器
<html > <head> <title>简单计算器</title> <style type="text/css"> ...
- jQuery/javascript实现简单网页计算器
<html> <head> <meta charset="utf-8"> <title>jQuery实现</title> ...
- 利用css和javascript实现简单的计算器
<!doctype html> <html> <head> <!--声明当前页面的编码集--> <meta http-equiv="Co ...
- JAVASCRIPT实现简单计算器
最终效果如下图-2,有bug:就是整数后点击%号结果正确,如果小数后面点击%的话结果就错误!其他都正常,求指点:input的value是string类型的,在JS中改如何正确处理下图-1中的if部分? ...
- javascript 简单的计算器
<%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx. ...
- js制作简单的计算器
学着做了一个简单的计算器!记录记录!哈哈 <!DOCTYPE html> <html> <head> <title>简单的计算器</title&g ...
- JS实现一个简单的计算器
使用JS完成一个简单的计算器功能.实现2个输入框中输入整数后,点击第三个输入框能给出2个整数的加减乘除.效果如上: 第一步: 创建构建运算函数count(). 第二步: 获取两个输入框中的值和获取选择 ...
- Java简单公式计算器
最近给公司开发业务代码时,碰到一个场景,简单描述是这样的: 客户要向咱们公司定制一件产品,这个产品呢,有很多属性,那公司得根据这些属性报价呀,怎么报价呢?公司针对某种类型的产品有一个基准价,在同类产品 ...
- JS事件 编程练习-自制计算器 使用JS完成一个简单的计算器功能。实现2个输入框中输入整数后,点击第三个输入框能给出2个整数的加减乘除。
编程练习 使用JS完成一个简单的计算器功能.实现2个输入框中输入整数后,点击第三个输入框能给出2个整数的加减乘除. 提示:获取元素的值设置和获取方法为:例:赋值:document.getElement ...
随机推荐
- 移动端WEB开发备忘录
META相关 1. 添加到主屏后的标题(IOS) <meta name="apple-mobile-web-app-title" content="标题" ...
- 读取.properties配置文件
方法1 public class SSOUtils { protected static String URL_LOGIN = "/uas/service/api/login/info&q ...
- 使用git删除远程仓库文件
git rm -r -f --cached 文件或文件夹 git commit -m "移除文件或文件夹" git push origin master 注意:要删除的文件或文件夹 ...
- js数组去重的方法
//数组去重 Array.prototype.unique = function() { var newArr = [], hash = {}; for(var i=0, len=this.lengt ...
- 第三章:Git使用入门
本文主要讲git的使用,其实网上这种教程已经很多了,但是还是要说一下,在这里先把基础的东西跟大家讲一下,然后再附上一个彩蛋,将一些别人不会提到的git技术,不要错过 哦! First: Git概念 1 ...
- SQL Server 检测到基于一致性的逻辑 I/O 错误 校验和不正确 ||尝试在数据库 5 中提取逻辑页 (1:1640) 失败
use test go ALTER DATABASE test SET SINGLE_USER DBCC CHECKDB (test, repair_allow_data_loss) with NO_ ...
- Linux学习 :移植U-boot_2016.09到JZ2440开发板
一.下载源码:ftp://ftp.denx.de/pub/u-boot/ 二.初始化编译: ①新建一个单板: cd board/samsung/ cp smdk2410 smdk2440 -rf ...
- extjs之apply
ext.apply(Ext.Form.VTypes,{}) {}里面的内容如下: { password:function (val.field) { if(field.initialPassField ...
- JAVA学习心得
学习JAVA一个学期了,虽然学的不是很好,也没有彻底理解JAVA的真正内涵,但是我认为学习java应该是循环渐进,有始有终,按部就班,脚踏实地.java是一门有着阶梯性的一门语言,信心,恒心,毅力是最 ...
- jsp数据交互(一),九大内置对象
九大内置对象 九大内置对象 内置对象 类型 说明 作用域 request javax.servlet.ServletRequest 请求对象——在 一次请求/一个Request请求周期 中传递数据,请 ...