亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

javascript-簡單的計算器實現步驟分解(附圖)

2019-11-20 22:40:40
字體:
來源:轉載
供稿:網友

知識點:
  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 'Microsoft yahei';
}
#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='num' />
</label></td>
<td><input type="button" value="8" _type='num' /></td>
<td><input type="button" value="9" _type='num' /></td>
<td><input type="button" value="/" _type='op' /></td>
</tr>
<tr>
<td><input type="button" value="4" _type='num' /></td>
<td><input type="button" value="5" _type='num' /></td>
<td><input type="button" value="6" _type='num' /></td>
<td><input type="button" value="*" _type='op' /></td>
</tr>
<tr>
<td><input type="button" value="1" _type='num' /></td>
<td><input type="button" value="2" _type='num' /></td>
<td><input type="button" value="3" _type='num' /></td>
<td><input type="button" value="-" _type='op' /></td>
</tr>
<tr>
<td><input type="button" value="0" _type='num' /></td>
<td><input type="button" value="+/-" _type='+/-' /></td>
<td><input type="button" value="." _type='.' /></td>
<td><input type="button" value="+" _type='op' /></td>
</tr>
<tr>
<td colspan="2" id="debug"><input type="button" value="backspace" _type='bs' /></td>
<td><input type="button" value="C" _type='cls' /></td>
<td><input type="button" value="=" _type='eval' /></td>
</tr>
</tbody>
</table>
<script>
//計算對象
var operateExp={
'+':function(num1,num2){return num1+num2;},
'-':function(num1,num2){return num1-num2;},
'*':function(num1,num2){return num1*num2;},
'/':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==='bs'){//退格鍵
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==='num'){//數字鍵
if(num==='0'||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

詳細分解:
第一:分支計算部分沒有使用switch 語句,使用了名值對的形式。
復制代碼 代碼如下:

//計算對象
var operateExp={
'+':function(num1,num2){return num1+num2;},
'-':function(num1,num2){return num1-num2;},
'*':function(num1,num2){return num1*num2;},
'/':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==='bs'){//退格鍵
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==='num'){//數字鍵
if(num==='0'||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);
}

PS:這里再為大家推薦兩款本站的在線計算器,都是采用js實現,且功能強大,相信對于大家深入了解JavaScript數學運算及web設計會有所幫助:

在線標準計算器:http://tools.VeVB.COm/jisuanqi/jsq

在線科學計算器:http://tools.VeVB.COm/jisuanqi/jsqkexue

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久久欧美一区二区| 成人免费xxxxx在线观看| 亚洲经典中文字幕| 久久福利视频网| 欧美老少配视频| 国产精品www网站| 国产精品入口日韩视频大尺度| 一本色道久久综合狠狠躁篇的优点| 国产精品成人在线| 国产美女精品视频免费观看| 国产欧美精品一区二区三区介绍| 97成人精品视频在线观看| 国产成人av网址| 日韩av不卡在线| 高清欧美性猛交| 亚洲一级黄色av| 大胆人体色综合| 亚洲品质视频自拍网| 久久理论片午夜琪琪电影网| 国产亚洲精品久久久| 91tv亚洲精品香蕉国产一区7ujn| 成人亚洲综合色就1024| 亚洲一级黄色片| 91av免费观看91av精品在线| 一区二区av在线| 国产精品劲爆视频| 日韩视频在线一区| 全亚洲最色的网站在线观看| 日韩中文字幕网| 国产高清在线不卡| 欧美激情精品久久久久久蜜臀| 国产精品一区二区三区毛片淫片| 亚洲欧美国产视频| 国产丝袜高跟一区| 成人黄色生活片| 国内精品美女av在线播放| 国产suv精品一区二区三区88区| 亚洲国产精品久久精品怡红院| 国产999精品久久久影片官网| 久久成人国产精品| 91手机视频在线观看| 欧美在线亚洲一区| 国产精品高潮呻吟久久av野狼| 亚洲成av人影院在线观看| 亚洲乱码国产乱码精品精天堂| 精品香蕉一区二区三区| 欧美成人性色生活仑片| 久久在线免费观看视频| 亚洲精品一区久久久久久| 国产日韩欧美影视| 国产精品一区二区久久国产| 国产精品久久久久久搜索| 日韩成人久久久| 在线不卡国产精品| 色偷偷偷综合中文字幕;dd| 超碰日本道色综合久久综合| 亚洲理论在线a中文字幕| 日韩国产高清污视频在线观看| 日韩暖暖在线视频| 亚洲第一视频在线观看| 久久亚洲综合国产精品99麻豆精品福利| 亚洲午夜精品久久久久久久久久久久| 日本精品在线视频| 欧美极品少妇xxxxⅹ免费视频| 最新国产精品拍自在线播放| 亚洲欧美国产精品久久久久久久| 国产精品久久久久久久久久免费| 另类视频在线观看| 国产精品嫩草影院一区二区| 91香蕉嫩草影院入口| 日本韩国欧美精品大片卡二| 亚洲a级在线播放观看| 久久久久久久久网站| 亚洲白虎美女被爆操| 蜜臀久久99精品久久久无需会员| 国产精品女视频| 国产精品一区久久久| 亚洲精品国产综合久久| 日韩精品在线视频观看| 色视频www在线播放国产成人| 国产成人精彩在线视频九色| 777午夜精品福利在线观看| 国产成人av在线播放| 欧美亚洲激情视频| 欧美黑人视频一区| 精品国内产的精品视频在线观看| 高跟丝袜一区二区三区| 亚洲free性xxxx护士hd| 九九热这里只有精品免费看| 久久精品人人爽| 亚洲日韩欧美视频| 国产色婷婷国产综合在线理论片a| 久久综合久久88| 日韩视频永久免费观看| 国产精品免费小视频| 疯狂做受xxxx欧美肥白少妇| 欧美精品videossex性护士| 欧美亚洲一级片| 国产欧美一区二区三区在线看| 亚洲一区二区三区四区视频| 18一19gay欧美视频网站| 成人h片在线播放免费网站| 在线观看国产欧美| 欧美一区第一页| 免费99精品国产自在在线| 久久精品久久久久久国产 免费| 欧美高清自拍一区| 亚洲午夜久久久久久久| 欧美精品videossex性护士| 一区二区在线免费视频| 亚洲图片制服诱惑| 深夜福利一区二区| 日韩免费不卡av| 91禁国产网站| 欧美一区二区三区免费视| 性欧美激情精品| 欧美电影《睫毛膏》| 国产91在线高潮白浆在线观看| 国产精品对白刺激| 亚洲美女av在线播放| 欧美日韩国产成人在线观看| 欧美做受高潮1| 国内精品视频在线| 亚洲精品黄网在线观看| 成人免费自拍视频| 伊是香蕉大人久久| 国产欧美欧洲在线观看| 亚洲视频欧洲视频| 日韩**中文字幕毛片| 国产欧美一区二区三区在线| 国产精品视频xxx| 国产精品男女猛烈高潮激情| 色偷偷av一区二区三区乱| 久久成人18免费网站| 欧美黑人xxxⅹ高潮交| 色偷偷噜噜噜亚洲男人| 黄网动漫久久久| 色婷婷成人综合| 亚洲最大的成人网| 国产69精品99久久久久久宅男| 亚洲第一福利网| 亚洲一区国产精品| 狠狠躁18三区二区一区| 日韩激情av在线免费观看| 中文字幕不卡在线视频极品| 亚洲视频欧美视频| 色先锋久久影院av| 色噜噜狠狠狠综合曰曰曰88av| 成人免费观看网址| 亚洲二区中文字幕| 韩国19禁主播vip福利视频| 国产亚洲精品久久久久久| 97久久久免费福利网址| 亚洲激情视频在线播放| 国产精品一区二区av影院萌芽| 久久国产精品久久久久久久久久| 日韩av网址在线| 欧美成人网在线| 亚洲国产精品久久久久秋霞蜜臀| 国产精品视频自在线| 精品久久久久久中文字幕| 日韩在线观看成人| 欧美激情一二区| 久久人人爽人人爽人人片av高请|