一个简单的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 相关文章推荐
JavaScript 指导方针
Apr 05 Javascript
JavaScript判断表单提交时哪个radio按钮被选中的方法
Mar 21 Javascript
原生JavaScript制作微博发布面板效果
Mar 11 Javascript
Node.js刷新session过期时间的实现方法推荐
May 18 Javascript
项目实践一图片上传之form表单还是base64前端图片压缩(前端图片压缩)
Jul 28 Javascript
jQuery插件FusionWidgets实现的Cylinder图效果示例【附demo源码】
Mar 23 jQuery
AngularJS对动态增加的DOM实现ng-keyup事件示例
Mar 12 Javascript
用Node提供静态文件服务的方法
Jul 06 Javascript
详解vue 项目白屏解决方案
Oct 31 Javascript
Vue+axios+WebApi+NPOI导出Excel文件实例方法
Jun 05 Javascript
微信小程序实现语音识别转文字功能及遇到的坑
Aug 02 Javascript
一篇文章告诉你如何实现Vue前端分页和后端分页
Feb 18 Vue.js
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
如何开始收听短波广播
2021/03/01 无线电
PHP Warning: Module 'modulename' already loaded in问题解决办法
2015/03/16 PHP
php+mysql实现的二级联动菜单效果详解
2016/05/10 PHP
php的lavarel框架中join和orWhere的用法
2020/12/28 PHP
在JavaScript中通过URL传递汉字的方法
2007/04/09 Javascript
jquery 如何动态添加、删除class样式方法介绍
2012/11/07 Javascript
基于jquery实现的文字淡入淡出效果
2013/11/14 Javascript
基于jquery实现等比缩放图片
2014/12/03 Javascript
jQuery中find()方法用法实例
2015/01/07 Javascript
JavaScript获取页面中超链接数量的方法
2015/11/09 Javascript
果断收藏9个Javascript代码高亮脚本
2016/01/06 Javascript
谈一谈JS消息机制和事件机制的理解
2016/04/14 Javascript
angularjs点击图片放大实现上传图片预览
2017/02/24 Javascript
整理关于Bootstrap过渡动画的慕课笔记
2017/03/29 Javascript
Angularjs使用指令做表单校验的方法
2017/03/31 Javascript
jQuery实现炫丽的3d旋转星空效果
2018/07/04 jQuery
微信小程序使用component自定义toast弹窗效果
2018/11/27 Javascript
vue-cli项目使用mock数据的方法(借助express)
2019/04/15 Javascript
vue设置动态请求地址的例子
2019/11/01 Javascript
Angular6项目打包优化的实现方法
2019/12/15 Javascript
javascript实现打砖块小游戏(附完整源码)
2020/09/18 Javascript
vue制作toast组件npm包示例代码
2020/10/29 Javascript
python解析基于xml格式的日志文件
2017/02/25 Python
python不换行之end=与逗号的意思及用途
2017/11/21 Python
Python地图绘制实操详解
2019/03/04 Python
python频繁写入文件时提速的方法
2019/06/26 Python
使用Python画了一棵圣诞树的实例代码
2020/11/27 Python
HTML5拍照和摄像机功能实战详解
2019/01/24 HTML / CSS
使用Html5 Stream开发实时监控系统
2020/06/02 HTML / CSS
女孩每月服装订阅盒:kidpik
2019/04/17 全球购物
adidas爱尔兰官方网站:阿迪达斯运动鞋和运动服
2019/11/01 全球购物
abstract是什么意思
2012/02/12 面试题
企业员工薪酬方案
2014/06/04 职场文书
后进生评语大全
2015/01/04 职场文书
党支部创先争优公开承诺书
2015/04/30 职场文书
超市主管竞聘书
2015/09/15 职场文书