JavaScript實(shí)現(xiàn)簡單的計(jì)算器
本文實(shí)例為大家分享了JavaScript實(shí)現(xiàn)簡單的計(jì)算器的具體代碼,供大家參考,具體內(nèi)容如下
整個(gè)計(jì)算器實(shí)現(xiàn)由html文件、js文件和css樣式表三部分組成
整體效果:body里放倆div,一個(gè)大的包一個(gè)小的,小的放鍵盤,鍵盤div里放鍵盤。

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:(將這段代碼寫在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在判斷無輸入或者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 字符串,并把它作為腳本代碼來執(zhí)行
resultDom.value =r;
}
//c歸零的
function clearzero(){
resultDom.value=0;
}
</script>
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
TypeScript 引用資源文件后提示找不到的異常處理技巧
這篇文章主要介紹了TypeScript 引用資源文件后提示找不到的異常處理,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-07-07
ajax讀取數(shù)據(jù)后使用jqchart顯示圖表的方法
這篇文章主要介紹了ajax讀取數(shù)據(jù)后使用jqchart顯示圖表的方法,涉及Ajax操作及圖表插件的相關(guān)使用技巧,需要的朋友可以參考下2015-06-06
JavaScript實(shí)現(xiàn)一個(gè)電子小蜘蛛
這篇文章主要介紹了JavaScript實(shí)現(xiàn)一個(gè)電子小蜘蛛,具體的樣子就是讓它會(huì)跟隨著我們的鼠標(biāo)進(jìn)行移動(dòng),那么我們?nèi)绾螌?shí)現(xiàn)這樣的效果呢,下面來詳細(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),并通過一些實(shí)例了解它的使用,字體圖標(biāo)是在 Web 項(xiàng)目中使用的圖標(biāo)字體。字體圖標(biāo)在下載的Bootstrap的fonts文件夾中2016-01-01
JavaScript生成二維數(shù)組的多種方法小結(jié)
我經(jīng)常在面試中問候:你能用?JavaScript?生成一個(gè)二維數(shù)組嗎?這個(gè)問題看似簡單,實(shí)際上卻能揭示出面試者對(duì)?JavaScript?的熟練程度,天,就讓我們一起來探索這個(gè)問題背后的答案,揭開生成二維數(shù)組的多種秘密,需要的朋友可以參考下2024-04-04

