JavaScript實現簡單的計算器
阿新 • • 發佈:2020-01-16
本文例項為大家分享了JavaScript實現簡單的計算器的具體程式碼,供大家參考,具體內容如下
整個計算器實現由html檔案、js檔案和css樣式表三部分組成
整體效果:body裡放倆div,一個大的包一個小的,小的放鍵盤,鍵盤div裡放鍵盤。
html:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>計算器</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:(將這段程式碼寫在body最下面)
<script type="text/javascript"> var resultDom = document.getElementById("result"); var operate = true; //操作符加鎖 var afequ = true; //點選計算器執行函式(點數字的時候) function command(num){ //點選等號之後要進行一次清空 if(!afequ) { clearzero(); } //獲取輸入框中value的值 var str = resultDom.value;//在這裡加一個判斷,如果第一位是0,就用""填充 str = (str == "0" ? "":str);//條件操作符 str在判斷無輸入或者0的時候 都算作是0 str += num; //拼接數字,然後賦值給文字框 resultDom.value = str;//.value獲取文字框中的值 operate = true; //鎖住操作符 } //四則運算 function tools(p,m){ if(operate){ var num = resultDom.value; num = (num == "0" ? "":num); resultDom.value = num + p; operate = false; } } //得出最後的結果 function equal(m){ var result = resultDom.value; var r = eval(result); //eval() 函式計算 JavaScript 字串,並把它作為指令碼程式碼來執行 resultDom.value =r; } //c歸零的 function clearzero(){ resultDom.value=0; } </script>
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援我們。