一个简单的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 相关文章推荐
jquery事件机制扩展插件 jquery鼠标右键事件
Dec 21 Javascript
div拖拽插件——JQ.MoveBox.js(自制JQ插件)
May 17 Javascript
JQuery对表单元素的基本操作使用总结
Jul 18 Javascript
JS实现Fisheye效果动感放大菜单代码
Oct 21 Javascript
详解Vue 非父子组件通信方法(非Vuex)
May 24 Javascript
浅谈Vue Element中Select下拉框选取值的问题
Mar 01 Javascript
vue-cli3添加模式配置多环境变量的方法
Jun 05 Javascript
vue实现树形结构样式和功能的实例代码
Oct 15 Javascript
Angular5整合富文本编辑器TinyMCE的方法(汉化+上传)
May 26 Javascript
详解js中的原型,原型对象,原型链
Jul 16 Javascript
在Vue中使用mockjs代码实例
Nov 25 Vue.js
js中Map和Set的用法及区别实例详解
Feb 15 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
2006/12/23 PHP
php中让上传的文件大小在上传前就受限制的两种解决方法
2013/06/24 PHP
php preg_replace替换实例讲解
2013/11/04 PHP
PHP加密技术的简单实现
2016/09/04 PHP
laravel框架的安装与路由实例分析
2019/10/11 PHP
使用JavaScript库还是自己写代码?
2010/01/28 Javascript
js的逻辑运算符 ||
2010/05/31 Javascript
js与jquery回车提交的方法
2015/02/03 Javascript
javascript格式化日期时间方法汇总
2015/06/19 Javascript
node.js请求HTTPS报错:UNABLE_TO_VERIFY_LEAF_SIGNATURE\的解决方法
2016/12/18 Javascript
JQuery Ajax 异步操作之动态添加节点功能
2017/05/24 jQuery
ES6使用Set数据结构实现数组的交集、并集、差集功能示例
2017/10/31 Javascript
vue 插槽简介及使用示例
2020/11/19 Vue.js
[49:54]Ti4 循环赛第三日 LGD vs Titan
2014/07/12 DOTA
探寻python多线程ctrl+c退出问题解决方案
2014/10/23 Python
在Python中移动目录结构的方法
2016/01/31 Python
python实现七段数码管和倒计时效果
2019/11/23 Python
解决pycharm导入本地py文件时,模块下方出现红色波浪线的问题
2020/06/01 Python
python获取百度热榜链接的实例方法
2020/08/25 Python
纯CSS3实现手风琴风格菜单具体步骤
2013/05/06 HTML / CSS
Foot Locker澳洲官网:美国运动服和鞋类零售商
2019/10/11 全球购物
银行实习人员自我鉴定
2013/09/22 职场文书
优秀研究生自我鉴定
2013/12/04 职场文书
高三高考决心书
2014/03/11 职场文书
个人自荐材料
2014/05/23 职场文书
纪念九一八事变83周年国旗下讲话稿
2014/09/15 职场文书
四风查摆问题及整改措施
2014/10/10 职场文书
2014年城市管理工作总结
2014/12/02 职场文书
2014年生活老师工作总结
2014/12/23 职场文书
学校光盘行动倡议书
2015/04/28 职场文书
文化大革命观后感
2015/06/17 职场文书
为什么node.js不适合大型项目
2021/04/28 Javascript
利用Selenium添加cookie实现自动登录的示例代码(fofa)
2021/05/08 Python
MySQL 分组查询的优化方法
2021/05/12 MySQL
微信小程序scroll-view不能左右滑动问题的解决方法
2021/07/09 Javascript
python通过新建环境安装tfx的问题
2022/05/20 Python