> 웹 프론트엔드 > JS 튜토리얼 > 간단한 계산기 구현 단계의 자바스크립트 분해

간단한 계산기 구현 단계의 자바스크립트 분해

高洛峰
풀어 주다: 2017-02-04 14:08:43
원래의
975명이 탐색했습니다.

지식 :
1. 수학연산 "+, -, *, /" 활용
2. 입력 내용 판단, 이벤트 객체의 출처 판단
효과 :

간단한 계산기 구현 단계의 자바스크립트 분해

코드:

<style> 
#calculate { 
line-height: 60px; 
text-align: center; 
background: #ccc; 
font-size: 16px; 
font-weight: bold; 
} 
#calculate tbody input{ 
width: 100%; 
height: 60px; 
background:#033; 
color: #fff; 
font: bold 16px/1em &#39;Microsoft yahei&#39;; 
} 
#calculate tbody td{ 
width: 25%; 
background: #fff; 
} 
#calculate_outPut{ 
font-size: 20px; 
letter-spacing:2px; 
background:#fff; 
height: 40px; 
border: none; 
text-align: right; 
width: 100%; 
} 
</style> 
<table width="300" border="0" cellspacing="1" cellpadding="0" id="calculate"> 
<thead > 
<tr> 
<td colspan="4" align="right"><input id="calculate_outPut" value="0" disabled="disabled"></td> 
</tr> 
</thead> 
<tbody id="calculate_num"> 
<tr> 
<td><label> 
<input type="button" name="button" id="button" value="7" _type=&#39;num&#39; /> 
</label></td> 
<td><input type="button" value="8" _type=&#39;num&#39; /></td> 
<td><input type="button" value="9" _type=&#39;num&#39; /></td> 
<td><input type="button" value="/" _type=&#39;op&#39; /></td> 
</tr> 
<tr> 
<td><input type="button" value="4" _type=&#39;num&#39; /></td> 
<td><input type="button" value="5" _type=&#39;num&#39; /></td> 
<td><input type="button" value="6" _type=&#39;num&#39; /></td> 
<td><input type="button" value="*" _type=&#39;op&#39; /></td> 
</tr> 
<tr> 
<td><input type="button" value="1" _type=&#39;num&#39; /></td> 
<td><input type="button" value="2" _type=&#39;num&#39; /></td> 
<td><input type="button" value="3" _type=&#39;num&#39; /></td> 
<td><input type="button" value="-" _type=&#39;op&#39; /></td> 
</tr> 
<tr> 
<td><input type="button" value="0" _type=&#39;num&#39; /></td> 
<td><input type="button" value="+/-" _type=&#39;+/-&#39; /></td> 
<td><input type="button" value="." _type=&#39;.&#39; /></td> 
<td><input type="button" value="+" _type=&#39;op&#39; /></td> 
</tr> 
<tr> 
<td colspan="2" id="debug"><input type="button" value="backspace" _type=&#39;bs&#39; /></td> 
<td><input type="button" value="C" _type=&#39;cls&#39; /></td> 
<td><input type="button" value="=" _type=&#39;eval&#39; /></td> 
</tr> 
</tbody> 
</table> 
<script> 
//计算对象 
var operateExp={ 
&#39;+&#39;:function(num1,num2){return num1+num2;}, 
&#39;-&#39;:function(num1,num2){return num1-num2;}, 
&#39;*&#39;:function(num1,num2){return num1*num2;}, 
&#39;/&#39;:function(num1,num2){return num2===0?0:num1/num2;} 
} 
//计算函数 
var operateNum=function(num1,num2,op){ 
if(!(num1&&num2))return; 
//保证num1,num2都为数字 
num1=Number(num1); 
num2=Number(num2); 
//不存在操作符,返回num1; 
if(!op)return num1; 
//匹配运算公式 
if(!operateExp[op])return 0; 
return operateExp[op](num1,num2); 
} 
//显示面板 
var calculate_outPut=document.getElementById("calculate_outPut"); 
//操作面板 
var calculate_num=document.getElementById("calculate_num"); 
var result=0;//计算结果 
var isReset=false;//是否重新设置 
var operation;//操作符 
//设置显示屏的值 
function setScreen(num){ 
calculate_outPut.value=num; 
} 
//获取显示屏的值 
function getScreen(){ 
return calculate_outPut.value; 
} 
//添加点击事件 
calculate_num.onclick=function(e){ 
var ev = e || window.event; 
var target = ev.target || ev.srcElement; 
if(target.type=="button"){ 
var mark=target.getAttribute("_type");//获取当前点击button的自定义的属性。 
var value=target.value;//获取当前的值 
var num=getScreen();//获取当前框的值 
if(mark===&#39;bs&#39;){//退格键 
if(num==0)return; 
var snum=Math.abs(num).toString(); 
if(snum.length<2) 
setScreen(0); 
else 
setScreen(num.toString().slice(0,-1)); 
} 
if(mark===&#39;num&#39;){//数字键 
if(num===&#39;0&#39;||isReset){//有操作符或显示屏为0 
setScreen(value); 
isReset=false; 
return; 
} 
setScreen(num.toString().concat(value)); 
} 
if(mark==="."){//小数点 
var hasPoint=num.toString().indexOf(".")>-1; 
if(hasPoint){ 
if(isReset){ 
setScreen("0"+value); 
isReset=false; 
return; 
} 
return; 
} 
setScreen(num.toString().concat(value)); 
} 
if(mark==="+/-"){//正负号 
setScreen(-num); 
} 
if(mark==="op"){//如果点击的是操作符则设计第一个操作数 
if(isReset)return; 
isReset=true; 
if(!operation){ 
result=+num; 
operation=value; 
return; 
} 
result=operateNum(result,num,operation); 
setScreen(result); 
operation=value; 
} 
if(mark==="cls"){//清零 
result=0; 
setScreen(result); 
isReset=false; 
} 
if(mark==="eval"){//计算 
if(!operation)return; 
result=operateNum(result,num,operation); 
setScreen(result); 
operation=null; 
isReset=false; 
} 
} 
} 
</script> 
View Code
로그인 후 복사

상세 분석:
첫 번째: 분기 계산 부분은 스위치 문을 사용하지 않고 이름-값 쌍의 형식을 사용합니다.

//计算对象 
var operateExp={ 
&#39;+&#39;:function(num1,num2){return num1+num2;}, 
&#39;-&#39;:function(num1,num2){return num1-num2;}, 
&#39;*&#39;:function(num1,num2){return num1*num2;}, 
&#39;/&#39;:function(num1,num2){return num2===0?0:num1/num2;} 
}
로그인 후 복사

둘째: 개체 이벤트의 속성을 사용하여 클릭한 개체의 유형을 가져옵니다. 이벤트 버블링을 사용하여 이벤트를 캡처하고 분류합니다.

calculate_num.onclick=function(e){ 
var ev = e || window.event; 
var target = ev.target || ev.srcElement; 
if(target.type=="button"){ 
var mark=target.getAttribute("_type");//获取当前点击button的自定义的属性。 
var value=target.value;//获取当前的值 
var num=getScreen();//获取当前框的值 
if(mark===&#39;bs&#39;){//退格键 
if(num==0)return; 
var snum=Math.abs(num).toString(); 
if(snum.length<2) 
setScreen(0); 
else 
setScreen(num.toString().slice(0,-1)); 
} 
if(mark===&#39;num&#39;){//数字键 
if(num===&#39;0&#39;||isReset){//有操作符或显示屏为0 
setScreen(value); 
isReset=false; 
return; 
} 
setScreen(num.toString().concat(value)); 
} 
if(mark==="."){//小数点 
var hasPoint=num.toString().indexOf(".")>-1; 
if(hasPoint){ 
if(isReset){ 
setScreen("0"+value); 
isReset=false; 
return; 
} 
return; 
} 
setScreen(num.toString().concat(value)); 
} 
if(mark==="+/-"){//正负号 
setScreen(-num); 
} 
if(mark==="op"){//如果点击的是操作符则设计第一个操作数 
if(isReset)return; 
isReset=true; 
if(!operation){ 
result=+num; 
operation=value; 
return; 
} 
result=operateNum(result,num,operation); 
setScreen(result); 
operation=value; 
} 
if(mark==="cls"){//清零 
result=0; 
setScreen(result); 
isReset=false; 
} 
if(mark==="eval"){//计算 
if(!operation)return; 
result=operateNum(result,num,operation); 
setScreen(result); 
operation=null; 
isReset=false; 
} 
} 
}
로그인 후 복사

셋째: 전역 변수 사용, 전역 변수를 사용하여 로컬 작업의 진행 상황을 제어합니다. (상태 제어)

var result=0;//计算结果 
var isReset=false;//是否重新设置 
var operation;//操作符
로그인 후 복사

넷째: 페이지 작업을 분리하고 분리합니다.

//设置显示屏的值 
function setScreen(num){ 
calculate_outPut.value=num; 
} 
//获取显示屏的值 
function getScreen(){ 
return calculate_outPut.value; 
}
로그인 후 복사

다섯째: 피연산자를 필터링하고 계산을 완료합니다.

//计算函数 
var operateNum=function(num1,num2,op){ 
if(!(num1&&num2))return; 
//保证num1,num2都为数字 
num1=Number(num1); 
num2=Number(num2); 
//不存在操作符,返回num1; 
if(!op)return num1; 
//匹配运算公式 
if(!operateExp[op])return 0; 
return operateExp[op](num1,num2); 
}
로그인 후 복사

자바스크립트-간단 계산기 구현 단계 분석 관련 기사를 더 보려면 PHP 중국어 웹사이트를 주목하세요!

관련 라벨:
원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
최신 이슈
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿