原生JS實現(xiàn)簡單計算器功能
本文實例為大家分享了JS實現(xiàn)簡單計算器功能的具體代碼,供大家參考,具體內(nèi)容如下
使用html和css寫出計算器的基本結(jié)構(gòu)和樣式,用原生JS實現(xiàn)計算器的加減乘除運算功能,只能計算簡單的兩位數(shù)的運算,不支持三個數(shù)連加或者連乘等等。一次計算完成之后再進(jìn)行下一次運算不需要clear,可以直接進(jìn)行下次運算。具體實現(xiàn)如下:
html結(jié)構(gòu):
<div id="box"> ? ? ? ? <!-- 文本框要禁止用戶輸入,只能通過代碼中的input.value來修改 --> ? ? ? ? <input id="display" type="text" value="0" disabled> ? ? ? ? ? ? <div class="btn">1</div> ? ? ? ? <div class="btn">2</div> ? ? ? ? <div class="btn">3</div> ? ? ? ? <div class="btn">+</div> ? ? ? ? <div class="btn">4</div> ? ? ? ? <div class="btn">5</div> ? ? ? ? <div class="btn">6</div> ? ? ? ? <div class="btn">-</div> ? ? ? ? <div class="btn">7</div> ? ? ? ? <div class="btn">8</div> ? ? ? ? <div class="btn">9</div> ? ? ? ? <div class="btn">*</div> ? ? ? ? <div class="btn">C</div> ? ? ? ? <div class="btn">0</div> ? ? ? ? <div class="btn">=</div> ? ? ? ? <div class="btn">/</div> </div>
css樣式:
#box {
? ? ? ? ? ? width: 500px;
? ? ? ? ? ? height: 600px;
? ? ? ? ? ? border: 1px solid #000000;
? ? ? ? }
?
? ? ? ? #display {
? ? ? ? ? ? width: 460px;
? ? ? ? ? ? height: 60px;
? ? ? ? ? ? margin: 15px;
? ? ? ? ? ? text-align: right;
? ? ? ? ? ? font-size: 60px;
? ? ? ? ? ? line-height: 60px;
? ? ? ? ? ? overflow: hidden;
? ? ? ? ? ? /* overflow: hidden; ?溢出隱藏 */
? ? ? ? ? ? /* text-overflow: ellipsis; ?文本溢出時顯示省略號 ?*/
? ? ? ? ? ? /* word-wrap: none; ? 強制不換行 */
? ? ? ? ? ? background: #ffffff;
? ? ? ? }
?
? ? ? ? .btn {
? ? ? ? ? ? width: 100px;
? ? ? ? ? ? height: 100px;
? ? ? ? ? ? border: 1px solid #000000;
? ? ? ? ? ? float: left;
? ? ? ? ? ? margin: 10px 11px;
? ? ? ? ? ? font-size: 40px;
? ? ? ? ? ? line-height: 100px;
? ? ? ? ? ? text-align: center;
? ? ? ? ? ? user-select: none;
?}JS代碼:
firstValue這個全局變量存儲第一次輸入的數(shù),input的input.value屬性也是一個變量,這個值既作為頁面上顯示的內(nèi)容,也是輸入的數(shù)值。讓這兩個值進(jìn)行運算,結(jié)果再顯示到輸入框中即可。bool變量作用:當(dāng)一次運算完成之后所有數(shù)值清零。
如果要實現(xiàn)用上一次的結(jié)果繼續(xù)參與運算這個功能,可以再設(shè)置一個全局變量result來存儲每次運算后的結(jié)果,當(dāng)下次輸入運算符號時,判斷firstValue和result,再決定用哪個值計算。當(dāng)點擊C按鈕時,所有值清空,返回初始狀態(tài)。
var input = document.getElementById("display");
var btnCollection = document.getElementsByClassName("btn");
var type;
var firstValue = 0;
var bool = false;
?
? ?for (var i = 0; i < btnCollection.length; i++) {
? ?// 獲取到每個按鍵并添加點擊事件。點擊后會觸發(fā)function中代碼執(zhí)行。
? ? ? ? ? ? btnCollection[i].onclick = function () {
? ? ? ? ? ? ? ? if(bool){
? ? ? ? ? ? ? ? ? ? input.value = "0";
? ? ? ? ? ? ? ? ? ? firstValue = 0;
? ? ? ? ? ? ? ? ? ? type = undefined;
? ? ? ? ? ? ? ? ? ? bool = false;
? ? ? ? ? ? ? ? }
?
? ? ? ? ? ? ? ? // input.value = this.innerHTML; ? ? ?//顯示點擊的數(shù)字在文本框內(nèi)
?
? ? ? ? ? ? ? ? if (!isNaN(Number(this.innerHTML))) {
? ? ? ? ? ? ? ? ? ? input.value = Number(input.value + this.innerHTML).toString();
? ? ? ? ? ? ? ? } else if (this.innerHTML !== "C" && this.innerHTML !== "=") {
? ? ? ? ? ? ? ? ? ? firstValue = Number(input.value);
? ? ? ? ? ? ? ? ? ? type = this.innerHTML;
? ? ? ? ? ? ? ? ? ? input.value = 0;
? ? ? ? ? ? ? ? } else if (this.innerHTML === "C") {
? ? ? ? ? ? ? ? ? ? firstValue = 0;
? ? ? ? ? ? ? ? ? ? type = undefined;
? ? ? ? ? ? ? ? ? ? input.value = "0";
? ? ? ? ? ? ? ? } else {
? ? ? ? ? ? ? ? ? ? switch (type) {
? ? ? ? ? ? ? ? ? ? ? ? case "+":
? ? ? ? ? ? ? ? ? ? ? ? ? ? input.value = (Number(input.value) + firstValue).toString();
? ? ? ? ? ? ? ? ? ? ? ? ? ? break;
? ? ? ? ? ? ? ? ? ? ? ? case "-":
? ? ? ? ? ? ? ? ? ? ? ? ? ? input.value = (firstValue - Number(input.value)).toString();
? ? ? ? ? ? ? ? ? ? ? ? ? ? break;
? ? ? ? ? ? ? ? ? ? ? ? case "*":
? ? ? ? ? ? ? ? ? ? ? ? ? ? input.value = (Number(input.value) * firstValue).toString();
? ? ? ? ? ? ? ? ? ? ? ? ? ? break;
? ? ? ? ? ? ? ? ? ? ? ? case "/":
? ? ? ? ? ? ? ? ? ? ? ? ? ? input.value = (firstValue / Number(input.value)).toString();
? ? ? ? ? ? ? ? ? ? ? ? ? ? break;
? ? ? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? ? ? ? bool = true;
? ? ? ? ? ? ? ? }
? ? ? ? ? ? }
? ? ? ? }
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
如何理解JS函數(shù)防抖和函數(shù)節(jié)流
函數(shù)防抖和函數(shù)節(jié)流都是對函數(shù)進(jìn)行特殊的設(shè)置,減少該函數(shù)在某一時間段內(nèi)頻繁觸發(fā)帶來的副作用。二者只是采用的設(shè)置方式和原理不一樣,其最終的目的是一樣的。2021-05-05
詳釋JavaScript執(zhí)行環(huán)境與執(zhí)行棧
一句話就可以概括:代碼 ( 包括函數(shù) ) 執(zhí)行時所需要的所有信息就是執(zhí)行環(huán)境。由于 ES 歷經(jīng)多個版本,所以執(zhí)行環(huán)境的標(biāo)準(zhǔn)也一直在變。文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
Javascript實現(xiàn)簡易天數(shù)計算器
這篇文章主要為大家詳細(xì)介紹了Javascript實現(xiàn)簡易天數(shù)計算器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-05-05

