JavaScript實(shí)現(xiàn)簡(jiǎn)單的計(jì)算器
本文實(shí)例為大家分享了JavaScript實(shí)現(xiàn)簡(jiǎn)單的計(jì)算器的具體代碼,供大家參考,具體內(nèi)容如下
整個(gè)計(jì)算器實(shí)現(xiàn)由html文件、js文件和css樣式表三部分組成
整體效果:body里放倆div,一個(gè)大的包一個(gè)小的,小的放鍵盤(pán),鍵盤(pán)div里放鍵盤(pán)。
html:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>計(jì)算器</title> <link rel="stylesheet" href="css/jsq_css.css"> </head> <body> <div class="bor"> <input type="text" class="s_text" οnfοcus="this.blur();" value="0" id="result"> <div class="main"> <li οnclick="command(7);">7</li> <li οnclick="command(8);">8</li> <li οnclick="command(9);">9</li> <li id="j_div" οnclick="tools('/','g')">÷</li> <li οnclick="command(4);">4</li> <li οnclick="command(5);">5</li> <li οnclick="command(6);">6</li> <li id="j_mul" οnclick="tools('*','g')">×</li> <li οnclick="command(1);">1</li> <li οnclick="command(2);">2</li> <li οnclick="command(3);">3</li> <li id="j_sub" οnclick="tools('-','g');">-</li> <li οnclick="command(0)";>0</li> <li id="j_c"οnclick="clearzero('j')">c</li> <li id="j_dy"οnclick="equal('j');">=</li> <li id="j_add" οnclick="tools('+','g')";>+</li> </ul> </div> </div> </body> </html>
css:
*{margin: 0;padding: 0} li{list-style: none} .bor{margin: 0 auto;width: 400px;height: 520px;border: 2px solid #000; margin-top: 50px;overflow: hidden;text-align: center;} .s_text{margin: 0 auto;width: 330px;height: 80px;margin-top: 15px; border: 2px solid #000000;font-size: 30px;padding-left: 20px;} .main{margin: 0 auto;width: 350px;height: 400px;margin-top: 15px;} .main ul{display: flex;height: 100%;justify-content: space-between;flex-wrap: wrap;} .main ul li{width: 80px;height: 80px;border: 1px solid #000000; text-align: center; line-height:80px;font-size: 36px;cursor: pointer ;} .main ul li:hover{background: #eeeeee;}
js:(將這段代碼寫(xiě)在body最下面)
<script type="text/javascript"> var resultDom = document.getElementById("result"); var operate = true; //操作符加鎖 var afequ = true; //點(diǎn)擊計(jì)算器執(zhí)行函數(shù)(點(diǎn)數(shù)字的時(shí)候) function command(num){ //點(diǎn)擊等號(hào)之后要進(jìn)行一次清空 if(!afequ) { clearzero(); } //獲取輸入框中value的值 var str = resultDom.value;//在這里加一個(gè)判斷, 如果第一位是0, 就用""填充 str = (str == "0" ? "":str);//條件操作符 str在判斷無(wú)輸入或者0的時(shí)候 都算作是0 str += num; //拼接數(shù)字, 然后賦值給文本框 resultDom.value = str;//.value獲取文本框中的值 operate = true; //鎖住操作符 } //四則運(yùn)算 function tools(p,m){ if(operate){ var num = resultDom.value; num = (num == "0" ? "":num); resultDom.value = num + p; operate = false; } } //得出最后的結(jié)果 function equal(m){ var result = resultDom.value; var r = eval(result); //eval() 函數(shù)計(jì)算 JavaScript 字符串,并把它作為腳本代碼來(lái)執(zhí)行 resultDom.value =r; } //c歸零的 function clearzero(){ resultDom.value=0; } </script>
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
TypeScript 引用資源文件后提示找不到的異常處理技巧
這篇文章主要介紹了TypeScript 引用資源文件后提示找不到的異常處理,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07ajax讀取數(shù)據(jù)后使用jqchart顯示圖表的方法
這篇文章主要介紹了ajax讀取數(shù)據(jù)后使用jqchart顯示圖表的方法,涉及Ajax操作及圖表插件的相關(guān)使用技巧,需要的朋友可以參考下2015-06-06使用javascript為網(wǎng)頁(yè)增加夜間模式
如何給Web頁(yè)面增加夜間模式功能? 其實(shí)所謂的夜間模式就是在頁(yè)面上增加一個(gè)透明的遮罩層,但是遮罩層會(huì)擋住頁(yè)面元素, 解決方法是 添加DIV,給DIV的outline屬性一個(gè)很大的outline-width值,用outline的邊框作為遮罩,這樣既能正常點(diǎn)擊頁(yè)面元素,又能達(dá)到夜間模式的效果2014-01-01JavaScript實(shí)現(xiàn)一個(gè)電子小蜘蛛
這篇文章主要介紹了JavaScript實(shí)現(xiàn)一個(gè)電子小蜘蛛,具體的樣子就是讓它會(huì)跟隨著我們的鼠標(biāo)進(jìn)行移動(dòng),那么我們?nèi)绾螌?shí)現(xiàn)這樣的效果呢,下面來(lái)詳細(xì)講解實(shí)現(xiàn)方法,需要的朋友可以參考下2024-10-10新發(fā)現(xiàn)一個(gè)騙鏈接的方法(js讀取cookies)
新發(fā)現(xiàn)一個(gè)騙鏈接的方法(js讀取cookies),需要的朋友可以參考下。2012-01-01詳解Bootstrap glyphicons字體圖標(biāo)
本章將講解Bootstrap glyphicons字體圖標(biāo),并通過(guò)一些實(shí)例了解它的使用,字體圖標(biāo)是在 Web 項(xiàng)目中使用的圖標(biāo)字體。字體圖標(biāo)在下載的Bootstrap的fonts文件夾中2016-01-01JavaScript生成二維數(shù)組的多種方法小結(jié)
我經(jīng)常在面試中問(wèn)候:你能用?JavaScript?生成一個(gè)二維數(shù)組嗎?這個(gè)問(wèn)題看似簡(jiǎn)單,實(shí)際上卻能揭示出面試者對(duì)?JavaScript?的熟練程度,天,就讓我們一起來(lái)探索這個(gè)問(wèn)題背后的答案,揭開(kāi)生成二維數(shù)組的多種秘密,需要的朋友可以參考下2024-04-04