一个简单的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 相关文章推荐
js中onload与onunload的使用示例
Aug 25 Javascript
JS控制一个DIV层在指定时间内消失的方法
Feb 17 Javascript
JS实现三级折叠菜单特效,其它级可自动收缩
Aug 06 Javascript
探究JavaScript函数式编程的乐趣
Dec 14 Javascript
用js制作淘宝放大镜效果
Oct 28 Javascript
ReactNative之键盘Keyboard的弹出与消失示例
Jul 11 Javascript
[js高手之路]寄生组合式继承的优势详解
Aug 28 Javascript
jquery+css实现下拉列表功能
Sep 03 jQuery
js使用Promise实现简单的Ajax缓存
Nov 14 Javascript
详解微信小程序自定义组件的实现及数据交互
Jul 22 Javascript
layui实现二维码弹窗、并下载到本地的方法
Sep 25 Javascript
微信小程序 冒泡事件原理解析
Sep 27 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
咖啡的植物学知识
2021/03/03 咖啡文化
php 设计模式之 工厂模式
2008/12/19 PHP
PHP 的异常处理、错误的抛出及回调函数等面向对象的错误处理方法
2012/12/07 PHP
非常精妙的PHP递归调用与静态变量使用
2012/12/16 PHP
PHP使用imagick读取PDF生成png缩略图的两种方法
2014/03/20 PHP
PHP命令行脚本接收传入参数的三种方式
2014/08/20 PHP
MyEclipse常用配置图文教程
2014/09/11 PHP
分享php多功能图片处理类
2016/05/15 PHP
使用Codeigniter重写insert的方法(推荐)
2017/03/23 PHP
PHP的PDO事务与自动提交
2019/01/24 PHP
TP5框架页面跳转样式操作示例
2020/04/05 PHP
jQuery EasyUI API 中文文档 - Form表单
2011/10/06 Javascript
jquery对dom的操作常用方法整理
2013/06/25 Javascript
js数组循环遍历数组内所有元素的方法
2014/01/18 Javascript
JQuery 图片滚动轮播示例代码
2014/03/24 Javascript
jQuery插件slides实现无缝轮播图特效
2015/04/17 Javascript
jquery实现很酷的网页顶部图标下拉菜单效果
2015/08/22 Javascript
jQuery滚动加载图片实现原理
2015/12/14 Javascript
限制文本框只能输入数字||只能是数字和小数点||只能是整数和浮点数
2016/05/27 Javascript
微信小程序 支付功能(前端)的实现
2017/05/24 Javascript
vue slot 在子组件中显示父组件传递的模板
2018/03/02 Javascript
使用vue制作探探滑动堆叠组件的实例代码
2018/03/07 Javascript
NodeJs入门教程之定时器和队列
2019/03/08 NodeJs
在Python的Flask框架下使用sqlalchemy库的简单教程
2015/04/09 Python
Python中shutil模块的学习笔记教程
2017/04/04 Python
在Python中实现shuffle给列表洗牌
2018/11/08 Python
详解opencv Python特征检测及K-最近邻匹配
2019/01/21 Python
对Pytorch中nn.ModuleList 和 nn.Sequential详解
2019/08/18 Python
Django nginx配置实现过程详解
2020/09/10 Python
如何用 Python 制作 GitHub 消息助手
2021/02/20 Python
金融专业毕业生自荐信
2014/06/26 职场文书
营销与策划实训报告
2014/11/05 职场文书
2015年七一建党节活动总结
2015/03/20 职场文书
如何用python绘制雷达图
2021/04/24 Python
Docker 镜像介绍以及commit相关操作
2022/04/13 Servers
Python代码实现双链表
2022/05/25 Python