亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2013年05月30日 15:48:39   投稿:whsnow  
輸入內(nèi)容的判斷,對于事件對象的來源的判斷以及數(shù)學(xué)運算“+,-,*,/”的使用,感興趣的朋友可以學(xué)習(xí)下

知識點:
  1、數(shù)學(xué)運算“+,-,*,/”的使用
  2、輸入內(nèi)容的判斷,對于事件對象的來源的判斷
效果:
 
代碼:

復(fù)制代碼 代碼如下:

<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;}
}
//計算函數(shù)
var operateNum=function(num1,num2,op){
if(!(num1&&num2))return;
//保證num1,num2都為數(shù)字
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;//計算結(jié)果
var isReset=false;//是否重新設(shè)置
var operation;//操作符
//設(shè)置顯示屏的值
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");//獲取當(dāng)前點擊button的自定義的屬性。
var value=target.value;//獲取當(dāng)前的值
var num=getScreen();//獲取當(dāng)前框的值
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'){//數(shù)字鍵
if(num==='0'||isReset){//有操作符或顯示屏為0
setScreen(value);
isReset=false;
return;
}
setScreen(num.toString().concat(value));
}
if(mark==="."){//小數(shù)點
var hasPoint=num.toString().indexOf(".")>-1;
if(hasPoint){
if(isReset){
setScreen("0"+value);
isReset=false;
return;
}
return;
}
setScreen(num.toString().concat(value));
}
if(mark==="+/-"){//正負(fù)號
setScreen(-num);
}
if(mark==="op"){//如果點擊的是操作符則設(shè)計第一個操作數(shù)
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

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

//計算對象
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;}
}

第二:對象事件的屬性的使用,獲取點擊對象的類型。利用事件冒泡,捕獲事件,并對事件進行分類處理。
復(fù)制代碼 代碼如下:

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");//獲取當(dāng)前點擊button的自定義的屬性。
var value=target.value;//獲取當(dāng)前的值
var num=getScreen();//獲取當(dāng)前框的值
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'){//數(shù)字鍵
if(num==='0'||isReset){//有操作符或顯示屏為0
setScreen(value);
isReset=false;
return;
}
setScreen(num.toString().concat(value));
}
if(mark==="."){//小數(shù)點
var hasPoint=num.toString().indexOf(".")>-1;
if(hasPoint){
if(isReset){
setScreen("0"+value);
isReset=false;
return;
}
return;
}
setScreen(num.toString().concat(value));
}
if(mark==="+/-"){//正負(fù)號
setScreen(-num);
}
if(mark==="op"){//如果點擊的是操作符則設(shè)計第一個操作數(shù)
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;
}
}
}

第三:全局變量的使用,利用全局變量對局部操作進度進行控制。(狀態(tài)控制) 
復(fù)制代碼 代碼如下:

var result=0;//計算結(jié)果
var isReset=false;//是否重新設(shè)置
var operation;//操作符

第四:對頁面操作進行分離,解耦合。
復(fù)制代碼 代碼如下:

//設(shè)置顯示屏的值
function setScreen(num){
calculate_outPut.value=num;
}
//獲取顯示屏的值
function getScreen(){
return calculate_outPut.value;
}

第五:過濾操作數(shù),完成計算。
復(fù)制代碼 代碼如下:

//計算函數(shù)
var operateNum=function(num1,num2,op){
if(!(num1&&num2))return;
//保證num1,num2都為數(shù)字
num1=Number(num1);
num2=Number(num2);
//不存在操作符,返回num1;
if(!op)return num1;
//匹配運算公式
if(!operateExp[op])return 0;
return operateExp[op](num1,num2);
}

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

在線標(biāo)準(zhǔn)計算器:http://tools.jb51.net/jisuanqi/jsq

在線科學(xué)計算器:http://tools.jb51.net/jisuanqi/jsqkexue

相關(guān)文章

  • js中for in的用法示例解析

    js中for in的用法示例解析

    使用js的朋友對其中for in的并不陌生吧,下面用示例為大家介紹下其具體使用方法
    2013-12-12
  • 最簡單的tab切換實例代碼

    最簡單的tab切換實例代碼

    下面小編就為大家?guī)硪黄詈唵蔚膖ab切換實例代碼。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-05-05
  • 微信小程序中實現(xiàn)微信支付完整步驟

    微信小程序中實現(xiàn)微信支付完整步驟

    這篇文章主要給大家介紹了關(guān)于微信小程序中實現(xiàn)微信支付的相關(guān)資料,微信小程序支付是一種常見的支付方式,實現(xiàn)起來相對較為復(fù)雜,文中通過代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-11-11
  • javascript+css3 實現(xiàn)動態(tài)按鈕菜單特效

    javascript+css3 實現(xiàn)動態(tài)按鈕菜單特效

    這篇文章主要介紹了javascript+css3 實現(xiàn)動態(tài)按鈕菜單特效的相關(guān)資料,需要的朋友可以參考下
    2016-02-02
  • javascript漢字轉(zhuǎn)拼音的代碼

    javascript漢字轉(zhuǎn)拼音的代碼

    javascript漢字轉(zhuǎn)拼音的代碼...
    2007-02-02
  • 微信小程序之 catalog 切換實現(xiàn)解析

    微信小程序之 catalog 切換實現(xiàn)解析

    這篇文章主要介紹了微信小程序之 catalog 切換實現(xiàn)解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-09-09
  • JavaScript使用DeviceOne開發(fā)實戰(zhàn)(四)仿優(yōu)酷視頻應(yīng)用

    JavaScript使用DeviceOne開發(fā)實戰(zhàn)(四)仿優(yōu)酷視頻應(yīng)用

    這篇文章主要介紹了JavaScript使用DeviceOne開發(fā)實戰(zhàn)(四)仿優(yōu)酷視頻應(yīng)用的相關(guān)資料,需要的朋友可以參考下
    2015-12-12
  • js中l(wèi)et能否完全替代IIFE

    js中l(wèi)et能否完全替代IIFE

    這篇文章主要介紹了js中l(wèi)et能否完全替代IIFE,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,,需要的朋友可以參考下
    2019-06-06
  • js選項卡的制作方法

    js選項卡的制作方法

    這篇文章主要為大家詳細(xì)介紹了js選項卡的制作方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-01-01
  • uniapp自定義應(yīng)用退出執(zhí)行內(nèi)容實例代碼

    uniapp自定義應(yīng)用退出執(zhí)行內(nèi)容實例代碼

    近幾日使用uni-app開發(fā)移動應(yīng)用APP遇到了個不常見的需求,下面這篇文章主要給大家介紹了關(guān)于uniapp自定義應(yīng)用退出執(zhí)行內(nèi)容的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-12-12

最新評論