一个简单的jQuery计算器实现了连续计算功能
一个简单的jQuery计算器,只是实现了一个连续计算的功能
<!DOCTYPEhtml>
<html>
<head>
<metacharset="utf8"/>
<title>Javascript计算器</title>
</head>
<body>
<table>
<tr>
<tdcolspan="4"><inputid="show"value="0"/></td>
</tr>
<tr>
<td><buttononclick="number(this)"value="7">7</button></td>
<td><buttononclick="number(this)"value="8">8</button></td>
<td><buttononclick="number(this)"value="9">9</button></td>
<td><buttononclick="calsym(this)"value="+">+</button></td>
</tr>
<tr>
<td><buttononclick="number(this)"value="4">4</button></td>
<td><buttononclick="number(this)"value="5">5</button></td>
<td><buttononclick="number(this)"value="6">6</button></td>
<td><buttononclick="calsym(this)"value="-">-</button></td>
</tr>
<tr>
<td><buttononclick="number(this)"value="1">1</button></td>
<td><buttononclick="number(this)"value="2">2</button></td>
<td><buttononclick="number(this)"value="3">3</button></td>
<td><buttononclick="calsym(this)"value="*">*</button></td>
</tr>
<tr>
<td><buttononclick="number(this)"value="0">0</button></td>
<td><buttononclick="calsym(this)"value="=">=</button></td>
<td><buttononclick="clearCal()"value="c">c</button></td>
<td><buttononclick="calsym(this)"value="/">/</button></td>
</tr>
</table>
</body>
<scripttype="text/javascript"src="jquery-1.9.1.js"></script>
<scripttype="text/javascript"src="jquery-1.9.1.min.js"></script>
<scripttype="text/javascript">
varnum0=null;
varnum1=null;
varsymble=null;
varlastclick=null;
varsymarr=newArray();//符号集合
symarr[0]='+';
symarr[1]='/';
symarr[2]='*';
symarr[3]='-';
symarr[4]='=';
functionnumber(n){
varnumnow=$('#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();//更新上次点击
}
functioncalsym(cs){//符号点击事件响应
varnumnow=$('#show');
var_exist=$.inArray(lastclick,symarr);
if(num0==null&&symble==null){//初始状态
num0=numnow.val();
symble=$(cs).val();
}elseif(num0!=null&&num1==null&&_exist!=-1){//连续点操作符的处理,及第一次点击操作符处理
symble=$(cs).val();
}else{//正常计算状态
num1=numnow.val();
varresult=calculate(symble,num0,num1);
symble=$(cs).val();//上行及本行:先计算之前的运算符及结果,再更新运算符为本次点击
num0=result;
numnow.val(result);
num1=null;
}
lastclick=$(cs).val();//更新上次点击
}
functionclearCal(){//清空函数
$('#show').val('0');
num0=null;
num1=null;
symble=null;
lastclick=null;
}
functioncalculate(sym,m,n){//计算并返回结果
varres=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;
}
returnres;
}
</script>
</html>