JavaScript制作简易计算器(不用eval)


Posted in Javascript onFebruary 05, 2017

本文实例为大家分享了js制作简易计算器的具体代码,供大家参考,具体内容如下

<head>
 <meta charset="UTF-8">
 <title>Title</title>
 <style type="text/css">
  * {
   padding: 0;
   margin: 0;
  }
  li {
   list-style: none;
  }
  body {
   background: #940032;
  }

  #counter {
   width: 500px;
   height: 420px;
   background: #939;
   margin: 50px auto 0;
   position: relative;
  }

  #counter h2 {
   line-height: 42px;
   padding-left: 15px;
   font-size: 14px;
   font-family: arial;
   color: #ff3333;
  }

  #counter a {
   font-weight: normal;
   text-decoration: none;
   color: #ff3333;
  }

  #counter a:hover {
   text-decoration: underline;
  }

  #bg {
   width: 280px;
   height: 200px;
   border: 3px solid #680023;
   background: #990033;
   filter: alpha(opacity=80);
   opacity: 0.8;
   position: absolute;
   left: 50%;
   top: 115px;
   margin-left: -141px;
  }

  #counter_content {
   width: 250px;
   position: absolute;
   top: 130px;
   left: 130px;
   z-index: 1;
  }

  #counter_content h3 {
   margin-bottom: 10px;
  }

  #counter_content h3 input {
   border: none;
   width: 223px;
   height: 30px;
   line-height: 30px;
   padding: 0 10px;
   background: url(img/ico.png) no-repeat;
   text-align: right;
   color: #333;
   font-size: 14px;
   font-weight: bold;
  }

  #counter_content div {
   width: 250px;
  }

  #counter_content input {
   width: 60px;
   height: 30px;
   line-height: 30px;
   float: left;
   background: url(img/ico.png) no-repeat -303px 0;
   text-align: center;
   color: #fff;
   cursor: pointer;
   margin: 0 1px 4px 0;
   border: 0;
  }

  #counter_content div > input:hover {
   background: url(img/ico.png) no-repeat -243px 0;
  }

  #counter p {
   width: 500px;
   position: absolute;
   bottom: 20px;
   left: 0;
   color: #ff3333;
   text-align: center;
   font-size: 12px;
  }
 </style>
</head>
<body>
<div id="counter">
 <h2>简易计算</h2>
 <div id="counter_content">
  <h3><input id="input1" type="text" value="0"/></h3>
  <div id="div1">
   <input type="button" value="7" onclick="kick('7')"/>
   <input type="button" value="8" onclick="kick('8')"/>
   <input type="button" value="9" onclick="kick('9')"/>
   <input type="button" value="+" onclick="kick('+')"/>
   <input type="button" value="4" onclick="kick('4')"/>
   <input type="button" value="5" onclick="kick('5')"/>
   <input type="button" value="6" onclick="kick('6')"/>
   <input type="button" value="-" onclick="kick('-')"/>
   <input type="button" value="1" onclick="kick('1')"/>
   <input type="button" value="2" onclick="kick('2')"/>
   <input type="button" value="3" onclick="kick('3')"/>
   <input type="button" value="*" onclick="kick('*')"/>
   <input type="button" value="0" onclick="kick('0')"/>
   <input type="button" value="C" onclick="kick('C')"/>
   <input type="button" value="=" onclick="kick('=')"/>
   <input type="button" value="/" onclick="kick('/')"/>
  </div>
 </div>
</div>
</body>
<script>
 var showInput = document.getElementById("input1");
 var isClear = false;
 var tempStr = "";
 var clacType = "";
 var isContinue = true;
 function kick(clickValue) {
  switch (clickValue) {
   case "=":
    if (tempStr != "" && clacType != "") {
     showInput.value = clac(tempStr, showInput.value, clacType);
     isContinue = false;
     clacType = "";
    }
    break;
   case "+":
   case "-":
   case "*":
   case "/":
    //如果预存的操作符不为空 表示表示连续操作
    if (clacType != "" && !isContinue) { //先执行计算
     tempStr = clac(tempStr, showInput.value, clacType);
     isClear = true;
     clacType = clickValue;
    } else {
     tempStr = showInput.value; //点击操作符之后 预存字符
     isClear = true;//表示点击了操作符
     clacType = clickValue;//预存操作符
    }
    isContinue = true;
    break;
   case "C":
    showInput.value = "0";
    isClear = false;
    tempStr = "";
    clacType = "";
    break;
   default://普通的数字按钮点击
    showInput.value = showInput.value == "0" ? "" : showInput.value;
    isContinue = false;
    if (isClear) {
     showInput.value = "";
     showInput.value += clickValue;
     isClear = false;
    } else {
     showInput.value += clickValue;
    }
    break;
  }
 }


 function clac(num1, num2, type) {
  switch (type) {
   case "+":
    return Number(num1) + Number(num2);
   case "-":
    return Number(num1) - Number(num2);
   case "*":
    return Number(num1) * Number(num2);
   case "/":
    return Number(num1) / Number(num2);
   default:
    break;
  }
  }
 </script>

关于计算器的精彩文章请查看《计算器专题》 ,更多精彩等你来发现!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
javascript for循环设法提高性能
Feb 24 Javascript
javascript 兼容所有浏览器的DOM扩展功能
Aug 01 Javascript
15条JavaScript最佳实践小结
Aug 09 Javascript
JavaScript中的分号插入机制详细介绍
Feb 11 Javascript
移除AngularJS下URL中的#字符的方法
Jun 19 Javascript
vue页面使用阿里oss上传功能的实例(二)
Aug 09 Javascript
探究react-native 源码的图片缓存问题
Aug 24 Javascript
基于vue.js路由参数的实例讲解——简单易懂
Sep 07 Javascript
详解Vue中localstorage和sessionstorage的使用
Dec 22 Javascript
jsonp跨域获取数据的基础教程
Jul 01 Javascript
js+css3实现简单时钟特效
Sep 13 Javascript
javascript实现倒计时提示框
Mar 02 Javascript
flexslider.js实现移动端轮播
Feb 05 #Javascript
简单实现js悬浮导航效果
Feb 05 #Javascript
用js制作淘宝放大镜效果
Oct 28 #Javascript
js实现百度搜索提示框
Feb 05 #Javascript
jQuery.Form上传文件操作
Feb 05 #Javascript
jQuery实现最简单实用的分秒倒计时
Feb 05 #Javascript
用jquery的attr方法实现图片切换效果
Feb 05 #Javascript
You might like
Yii2分页的使用及其扩展方法详解
2016/05/23 PHP
PHP实现非阻塞模式的方法分析
2018/07/26 PHP
简单三步,搞掂内存泄漏
2007/03/10 Javascript
比较详细的关于javascript 解析json的代码
2009/12/16 Javascript
jquery tab标签页的制作
2010/05/10 Javascript
浏览器脚本兼容 文本框中,回车键触发事件的兼容
2010/06/21 Javascript
js的隐含参数(arguments,callee,caller)使用方法
2014/01/28 Javascript
Vue2实现组件props双向绑定
2016/12/02 Javascript
jQuery.Validate表单验证插件的使用示例详解
2017/01/04 Javascript
xmlplus组件设计系列之树(Tree)(9)
2017/05/02 Javascript
react 应用多入口配置及实践总结
2018/10/17 Javascript
angularjs自定义过滤器demo示例
2019/08/24 Javascript
layui radio单选限制下一个radio单选的实例
2019/09/03 Javascript
详解Vite的新体验
2021/02/22 Javascript
vue脚手架项目创建步骤详解
2021/03/02 Vue.js
Python 网络编程起步(Socket发送消息)
2008/09/06 Python
python线程锁(thread)学习示例
2013/12/04 Python
详解Django中的权限和组以及消息
2015/07/23 Python
Python二叉搜索树与双向链表转换实现方法
2016/04/29 Python
Python容器使用的5个技巧和2个误区总结
2019/09/26 Python
Python图像处理库PIL的ImageEnhance模块使用介绍
2020/02/26 Python
python matplotlib imshow热图坐标替换/映射实例
2020/03/14 Python
如何理解python中数字列表
2020/05/29 Python
python 利用panda 实现列联表(交叉表)
2021/02/06 Python
安纳塔拉酒店度假村及水疗官方网站:Anantara Hotel
2016/08/25 全球购物
英国家电购物网站:Sonic Direct
2019/03/26 全球购物
2014年消防工作实施方案
2014/02/20 职场文书
电视节目策划方案
2014/05/16 职场文书
巴西世界杯32强口号
2014/06/05 职场文书
工地门卫岗位职责范本
2014/07/01 职场文书
师德自我剖析材料范文
2014/10/06 职场文书
学院党委班子四风问题自查报告及整改措施
2014/10/25 职场文书
2014年综治维稳工作总结
2014/11/17 职场文书
2016年寒假社会实践活动心得体会
2015/10/09 职场文书
Java elasticsearch安装以及部署教程
2021/06/28 Java/Android
React四级菜单的实现
2022/04/08 Javascript