成功进化到程序猿快一年多了, 还没写过计算器, 正好今天比较闲,随手写了个计算器,最简单的实现,核心是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,简单的计算器实现的更多相关文章

  1. 用JavaScript制作简单的计算器

    <html > <head> <title>简单计算器</title> <style type="text/css"> ...

  2. jQuery/javascript实现简单网页计算器

    <html> <head> <meta charset="utf-8"> <title>jQuery实现</title> ...

  3. 利用css和javascript实现简单的计算器

    <!doctype html> <html> <head> <!--声明当前页面的编码集--> <meta http-equiv="Co ...

  4. JAVASCRIPT实现简单计算器

    最终效果如下图-2,有bug:就是整数后点击%号结果正确,如果小数后面点击%的话结果就错误!其他都正常,求指点:input的value是string类型的,在JS中改如何正确处理下图-1中的if部分? ...

  5. javascript 简单的计算器

    <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx. ...

  6. js制作简单的计算器

    学着做了一个简单的计算器!记录记录!哈哈 <!DOCTYPE html> <html> <head> <title>简单的计算器</title&g ...

  7. JS实现一个简单的计算器

    使用JS完成一个简单的计算器功能.实现2个输入框中输入整数后,点击第三个输入框能给出2个整数的加减乘除.效果如上: 第一步: 创建构建运算函数count(). 第二步: 获取两个输入框中的值和获取选择 ...

  8. Java简单公式计算器

    最近给公司开发业务代码时,碰到一个场景,简单描述是这样的: 客户要向咱们公司定制一件产品,这个产品呢,有很多属性,那公司得根据这些属性报价呀,怎么报价呢?公司针对某种类型的产品有一个基准价,在同类产品 ...

  9. JS事件 编程练习-自制计算器 使用JS完成一个简单的计算器功能。实现2个输入框中输入整数后,点击第三个输入框能给出2个整数的加减乘除。

    编程练习 使用JS完成一个简单的计算器功能.实现2个输入框中输入整数后,点击第三个输入框能给出2个整数的加减乘除. 提示:获取元素的值设置和获取方法为:例:赋值:document.getElement ...

随机推荐

  1. java动手动脑和课后实验型问题

    1.以下代码的输出结果是什么?为什么会有这个结果? int[] a = { 5, 7, 20 }; System.out.println("a数组中的元素:"); // 循环输出a ...

  2. opacity背景层透明导致文字也透明

    如果想要文字和背景分开,即背景透明了,但是文字不影响 解决方法:高级浏览器用background:rgba();来解决 低级浏览器,给文字层加相对定位 http://www.360doc.com/co ...

  3. android两种基本联网方式与一种第三方开源项目的使用

    安卓请求网络的三种方式 在请求网络的时候一般常用的提交方式是post或者get请求,post请求安全,传输大小无限制,但是代码量多些,get请求是浏览器有大小限制,用户提交的信息在浏览器的地址栏显示出 ...

  4. C++中的字面值指定类型

    C++中只有内置类型存在字面值,没有类(class)类型字面值.例如:0是int类型的字面值,3.14159是double类型的字面值. 字面值类型很多 整型浮点字面值 20             ...

  5. c语言函数, 函数调用及函数递归

    1. 函数的定义: 返回值类型 函数名(形参列表) {函数体(函数的实现内容)}, 注意: 如果没有参数, 小括号也是必不可少的.  函数与函数之间可以嵌套调用(也就是在一个函数内部可以调用另外一个函 ...

  6. nRF24L01芯片控制——迈向无线的第一步

    nRF24L01芯片是一款专供单片机的射频收发芯片.工作于2.4GHz~2.5GHz ISM频段.融合了shockburst技术. 我先列出该芯片的硬件参数资料: 至于每个引脚的具体用途,可以参见技术 ...

  7. leetcode6

    好吧,今天晚上赶项目确实是做不了三道题目了,最近项目在网络编程方面有些进步,学到了东西,有时间再积累下来,很深的体会就是,和别人一起写代码,虽然蛋疼但是比自己一个人写要好点,不过发现自己对链表和排序什 ...

  8. HTML 中级2

    <colgroup> 标签用于对表格中的列进行组合,以便对其进行格式化. 通过使用 <colgroup> 标签,可以向整个列应用样式,而不需要重复为每个单元格或每一行设置样式. ...

  9. Redux教程2:链接React

    通过前面的教程,我们有了简单的环境,并且可以运行Redux的程序,也对 如何编写Redux示例 有了初步的印象: 掌握了 使用Redux控制状态转移 ,继而驱动 React 组件发生改变,这才是学习R ...

  10. 【浅层优化实战】ssh远程登录Linux卡慢的全过程排查及解决方案

    ssh远程登录Linux卡慢的全过程排查及解决方案 前言: 在linux操作系统使用过程中偶然一次感到使用ssh远程连接软件连接操作系统需要等待许久,第一次没在意,第二次也没在意,第三次有点忍受不住了 ...