JavaScript實現(xiàn)簡單的計算器
更新時間:2020年01月16日 08:29:05 作者:SSSkyCong
這篇文章主要為大家詳細介紹了JavaScript實現(xiàn)簡單的計算器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
本文實例為大家分享了JavaScript實現(xiàn)簡單的計算器的具體代碼,供大家參考,具體內(nèi)容如下
整個計算器實現(xiàn)由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;
//點擊計算器執(zhí)行函數(shù)(點數(shù)字的時候)
function command(num){
//點擊等號之后要進行一次清空
if(!afequ) {
clearzero();
}
//獲取輸入框中value的值
var str = resultDom.value;//在這里加一個判斷, 如果第一位是0, 就用""填充
str = (str == "0" ? "":str);//條件操作符 str在判斷無輸入或者0的時候 都算作是0
str += num; //拼接數(shù)字, 然后賦值給文本框
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;
}
}
//得出最后的結(jié)果
function equal(m){
var result = resultDom.value;
var r = eval(result); //eval() 函數(shù)計算 JavaScript 字符串,并把它作為腳本代碼來執(zhí)行
resultDom.value =r;
}
//c歸零的
function clearzero(){
resultDom.value=0;
}
</script>
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript使用前綴樹(trie樹)實現(xiàn)文本高亮
這篇文章主要為大家詳細介紹了JavaScript如何使用前綴樹(trie樹)實現(xiàn)文本高亮效果,文中的示例代碼講解詳細,有需要的小伙伴可以參考下2024-04-04
關(guān)于js獲取radio和select的屬性并控制的代碼
對于聯(lián)動菜單大家都不會陌生了,但是這還是我第一次寫聯(lián)動的了。原理很簡單,但是自己寫起來就感覺還是有點難度的了2011-05-05
js重寫alert事件(避免alert彈框標(biāo)題出現(xiàn)網(wǎng)址)
這篇文章主要給大家介紹了關(guān)于js重寫alert事件的相關(guān)資料,這樣可以避免alert彈框標(biāo)題出現(xiàn)網(wǎng)址的情況,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12

