一个简单的jQuery计算器实现了连续计算功能


Posted in Javascript onJuly 21, 2014

一个简单的jQuery计算器,只是实现了一个连续计算的功能

<!DOCTYPE html> 
<html> 
<head> 
<meta charset="utf8"/> 
<title>Javascript计算器</title> 
</head> 
<body> 
<table> 
<tr> 
<td colspan="4"><input id="show" value="0"/></td> 
</tr> 
<tr> 
<td><button onclick="number(this)" value="7">7</button></td> 
<td><button onclick="number(this)" value="8">8</button></td> 
<td><button onclick="number(this)" value="9">9</button></td> 
<td><button onclick="calsym(this)" value="+">+</button></td> 
</tr> 
<tr> 
<td><button onclick="number(this)" value="4">4</button></td> 
<td><button onclick="number(this)" value="5">5</button></td> 
<td><button onclick="number(this)" value="6">6</button></td> 
<td><button onclick="calsym(this)" value="-">-</button></td> 
</tr> 
<tr> 
<td><button onclick="number(this)" value="1">1</button></td> 
<td><button onclick="number(this)" value="2">2</button></td> 
<td><button onclick="number(this)" value="3">3</button></td> 
<td><button onclick="calsym(this)" value="*">*</button></td> 
</tr> 
<tr> 
<td><button onclick="number(this)" value="0">0</button></td> 
<td><button onclick="calsym(this)" value="=">=</button></td> 
<td><button onclick="clearCal()" value="c">c</button></td> 
<td><button onclick="calsym(this)" value="/">/</button></td> 
</tr> 
</table> 
</body> 
<script type="text/javascript" src="jquery-1.9.1.js"></script> 
<script type="text/javascript" src="jquery-1.9.1.min.js"></script> 
<script type="text/javascript"> 
var num0 = null; 
var num1 = null; 
var symble = null; 
var lastclick = null; 
var symarr = new Array(); //符号集合 
symarr[0] = '+'; 
symarr[1] = '/'; 
symarr[2] = '*'; 
symarr[3] = '-'; 
symarr[4] = '='; 
function number(n){ 
var numnow = $('#show'); 
var _exist=$.inArray(lastclick,symarr); //判断上次点击是否为符号 
if (numnow.val() == 0 || _exist != -1) {//若显示框为0 或者上次点击为符号,则重新记录显示框 
numnow.val($(n).val()); 
}else{ 
numnow.val(parseInt(numnow.val()) * 10 +parseInt($(n).val())); 
} 
lastclick = $(n).val(); // 更新上次点击 
} 

function calsym(cs){ //符号点击事件响应 
var numnow = $('#show'); 
var _exist=$.inArray(lastclick,symarr); 
if (num0 == null && symble == null) { //初始状态 
num0 = numnow.val(); 
symble = $(cs).val(); 
}else if(num0 != null && num1 == null && _exist !=-1){ // 连续点操作符的处理,及第一次点击操作符处理 
symble = $(cs).val(); 
}else{ //正常计算状态 
num1 = numnow.val(); 
var result = calculate(symble,num0,num1); 
symble = $(cs).val(); //上行及本行:先计算之前的运算符及结果,再更新运算符为本次点击 
num0 = result; 
numnow.val(result); 
num1 = null; 
} 
lastclick = $(cs).val(); // 更新上次点击 
} 

function clearCal(){ //清空函数 
$('#show').val('0'); 
num0 = null; 
num1 = null; 
symble = null; 
lastclick = null; 
} 

function calculate(sym,m,n){ //计算并返回结果 
var res = null; 
m = parseInt(m); 
n = parseInt(n); 
switch(sym){ 
case '+': 
res = m+n; 
break; 
case '-': 
res = m-n; 
break; 
case '*': 
res = m*n; 
break; 
case '/': 
if (n == 0) { 
alert("false"); 
break; 
} 
res = m/n; 
break; 
default: 
break; 
} 
return res; 
} 
</script> 
</html>
Javascript 相关文章推荐
在线编辑器中换行与内容自动提取
Apr 24 Javascript
Javascript获取当前日期的农历日期代码
Oct 08 Javascript
javascript解析xml实现省市县三级联动的方法
Jul 25 Javascript
基于HTML+CSS,jQuery编写的简易计算器后续(添加了键盘监听)
Jan 05 Javascript
js获取时间函数及扩展函数的方法
Oct 30 Javascript
深入了解JavaScript的逻辑运算符(与、或)
Dec 20 Javascript
JavaScript中的编码和解码函数
Feb 15 Javascript
微信小程序实现image组件图片自适应宽度比例显示的方法
Jan 16 Javascript
Angular利用内容投射向组件输入ngForOf模板的方法
Mar 05 Javascript
Koa2微信公众号开发之消息管理
May 16 Javascript
element-ui 关于获取select 的label值方法
Aug 24 Javascript
使用JS前端技术实现静态图片局部流动效果
Aug 05 Javascript
JavaScript访问CSS属性的几种方式介绍
Jul 21 #Javascript
javascript实现的元素拖动函数宿主为浏览器
Jul 21 #Javascript
javascript定义变量时有var和没有var的区别探讨
Jul 21 #Javascript
JQuery中$(document)是什么意思有什么作用
Jul 21 #Javascript
jquery显示隐藏input对象
Jul 21 #Javascript
jquery实现保存已选用户
Jul 21 #Javascript
jquery实现显示已选用户
Jul 21 #Javascript
You might like
PHP利用imagick生成组合缩略图
2016/02/19 PHP
关于laravel 日志写入失败问题汇总
2019/10/17 PHP
ThinkPHP5框架中使用JWT的方法示例
2020/06/03 PHP
Javascript实例教程(19) 使用HoTMetal(7)
2006/12/23 Javascript
非html5实现js版弹球游戏示例代码
2013/09/22 Javascript
JavaScript的setAttribute兼容性问题解决方法
2013/11/11 Javascript
文本框(input)获取焦点(onfocus)时样式改变的示例代码
2014/01/10 Javascript
JavaScript使用指针操作实现约瑟夫问题实例
2015/04/07 Javascript
vue.js初学入门教程(1)
2016/11/03 Javascript
vue双向绑定的简单实现
2016/12/22 Javascript
工作中常用的js、jquery自定义扩展函数代码片段汇总
2016/12/22 Javascript
jquery基于layui实现二级联动下拉选择(省份城市选择)
2017/06/20 jQuery
jquery插件开发之选项卡制作详解
2017/08/30 jQuery
Cpage.js给组件绑定事件的实现代码
2017/08/31 Javascript
小程序tab页无法传递参数的方法
2018/08/03 Javascript
jQuery实现动态生成年月日级联下拉列表示例
2019/05/11 jQuery
react koa rematch 如何打造一套服务端渲染架子
2019/06/26 Javascript
JS如何在数组指定位置插入元素
2020/03/10 Javascript
高效测试用例组织算法pairwise之Python实现方法
2017/07/19 Python
python的Crypto模块实现AES加密实例代码
2018/01/22 Python
python-tkinter之按钮的使用,开关方法
2019/06/11 Python
python文件转为exe文件的方法及用法详解
2019/07/08 Python
flask框架路由常用定义方式总结
2019/07/23 Python
python从内存地址上加载python对象过程详解
2020/01/08 Python
用python爬虫批量下载pdf的实现
2020/12/01 Python
用Python制作音乐海报
2021/01/26 Python
印度在线内衣和时尚目的地:Zivame
2017/09/28 全球购物
标记环介质访问控制协议
2016/03/27 面试题
党的群众路线教育实践活动批评与自我批评
2014/02/16 职场文书
护理中职生求职信范文
2014/02/24 职场文书
公证书格式
2015/01/23 职场文书
债务追讨律师函
2015/06/24 职场文书
总经理致辞
2015/07/29 职场文书
如何写好一份优秀的工作总结?
2019/06/21 职场文书
超级实用!五步法则,教你写好年终工作总结
2019/12/05 职场文书
vue实现可以快进后退的跑马灯组件
2022/04/08 Vue.js