現在電卓をjavascriptを用いて作成しているのですが、あるサイトを参考にしながら作成していたところ、そのサイトの中のコードでvar is_calc = false;を変数に定義して、コードを書いているのですが、なぜこれを使うと=で計算したかどうかになるのかが分かりません。
以下がコードになります。
分かりにくい質問かとは思いますがご回答のほどよろしくお願いします。
HTML
<div class="wrapper"> <h1 id="header">電卓</h1> <div id="calc"> <div> <input readonly id="result" type="text" value="0"> <button onclick="c_click()">C</button> </div> <div> <button onclick="num_click(this.innerHTML)">7</button> <button onclick="num_click(this.innerHTML)">8</button> <button onclick="num_click(this.innerHTML)">9</button> <button onclick="ope_click(this.innerHTML)">÷</button> </div> <div> <button onclick="num_click(this.innerHTML)">4</button> <button onclick="num_click(this.innerHTML)">5</button> <button onclick="num_click(this.innerHTML)">6</button> <button onclick="ope_click(this.innerHTML)">×</button> </div> <div> <button onclick="num_click(this.innerHTML)">1</button> <button onclick="num_click(this.innerHTML)">2</button> <button onclick="num_click(this.innerHTML)">3</button> <button onclick="ope_click(this.innerHTML)">-</button> </div> <div> <button onclick="num_click(this.innerHTML)">0</button> <button onclick="num_click(this.innerHTML)">.</button> <button onclick="equal_click()">=</button> <button onclick="ope_click(this.innerHTML)">+</button> </div> </div> </div>
CSS
@charset "utf-8"; /*全体*/ .wrapper{ max-width: 350px; margin: 0 auto; color: #666; } #header,#calc{ box-sizing: border-box; text-align: center; } /*ヘッダー*/ #header { font-size: 24px; padding: 1rem; } /*テキスト*/ input{ box-sizing: border-box; width: 75%; height: 3.5rem; font-size: 1.6rem; text-align: right; padding: 0 0.75rem; } /*ボタン関係*/ button{ font-size: 18px; width: 25%; height: 3.5rem; color: #333; vertical-align: middle; border-color: #fff; } button:hover{ background-color: #ddd; }
javascript
var result = ""; // =で計算したかどうか var is_calc = false; // 初期表示 window.onload = function () { result = document.getElementById('result'); }; // Cキー押下 function c_click(){ result.value = "0"; is_calc = false; } // 数字キー押下 function num_click(val){ if(is_calc) result.value = "0"; is_calc = false; if(result.value =="0" && val == "0"){ result.value = "0"; }else if(result.value == "0" && val == "."){ result.value = "0."; }else if(result.value == "0"){ result.value = val; }else{ result.value += val; } } // 演算子キー押下 function ope_click(val){ if(is_calc) is_calc = false; if(is_ope_last()){ result.value = result.value.slice(0, -1) + val; } else { result.value += val; } } // =キークリック function equal_click(){ if(is_ope_last()) result.value = result.value.slice(0, -1); var temp = new Function("return " + result.value.replaceAll("×", "*").replaceAll("÷", "/"))(); if(temp == Infinity || Number.isNaN(temp)){ result.value = "Error"; }else{ result.value = temp; is_calc = true; } } // 入力されている値が演算子かどうか function is_ope_last(){ return ["+","-","×","÷"].includes(result.value.toString().slice(-1)); }
このままではコードが読みづらいので、質問を編集し、</>(コードの挿入)ボタンを押し、出てくる’’’の枠の中にコードを貼り付けてください
まだ回答がついていません
会員登録して回答してみよう