在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
背景由于我又被分进了一个新的项目组,该项目需要用js,因为我没接触过,所以领导准备给我一周时间学习,没错,实现一个简单的支持四则混合运算的计算器就是作业,所以有了这篇文章 实现效果最终展现的页面如下图,当鼠标点击按键时,按键会变色,可以进行四则混合运算 上面一行显示计算式,当按下“=”时,显示计算结果 用到的技术计算器的页面是使用html的table绘制的 实现思路这里我分了三个文件,一个.html 一个 .css 一个 .js 1、先写了html和css,绘制出来网页展示的样子,此处不细说,有兴趣可以直接看代码 上面显示算式和结果的时候,我定义了一个全局变量的数组,每次点击按键,就把点击的那个按键的值push到数组里,这样显示的时候就直接把数组丢过去。这样做的还有一个原因是点击退格键的时候就pop一下,点击清空键的时候就直接赋个空数组给数组变量,操作起来会容易一些 接着很重要的一步是计算表达式,比如说输入 3 * 4.5 - 1= 这样的一个表达式,怎么去求值呢,我想到的方法是先把输入的数组变成变成中缀表达式,再由中缀表达式转成后缀表达式,然后再进行后缀表达式求值 1. 首先通过上面的数组处理得到了这样的一个数组['3','*','4','.','5','-','1'] 由于4.5步是数据结构中栈应用的内容,不清楚的可以回顾一下数据结构,至此就全部完成 具体实现代码如上,分析的已经够多了,所以这块就话不多说,直接上代码 .html文件 <!DOCTYPE html> <html> <head> <title>calculator</title> <link rel="stylesheet" href="calculator.css" > <script src="calculator.js"></script> </head> <body> <div> <table border="1"> <thead> <th colspan="4"> <input type="text" id="result" disabled> </th> </thead> <tbody> <tr> <td><button class="operate" onclick="showNumber(this)">(</button></td> <td><button class="operate" onclick="showNumber(this)">)</button></td> <td><button class="operate" onclick="clearOneResult()">←</button></td> <td><button class="operate" onclick="clearResult()">C</button></td> </tr> <tr> <td><button class="calculate" onclick="showNumber(this)">7</button></td> <td><button class="calculate" onclick="showNumber(this)">8</button></td> <td><button class="calculate" onclick="showNumber(this)">9</button></td> <td><button class="operate" onclick="showNumber(this)">*</button></td> </tr> <tr> <td><button class="calculate" onclick="showNumber(this)">4</button></td> <td><button class="calculate" onclick="showNumber(this)">5</button></td> <td><button class="calculate" onclick="showNumber(this)">6</button></td> <td><button class="operate" onclick="showNumber(this)">-</button></td> </tr> <tr> <td><button class="calculate" onclick="showNumber(this)">1</button></td> <td><button class="calculate" onclick="showNumber(this)">2</button></td> <td><button class="calculate" onclick="showNumber(this)">3</button></td> <td><button class="operate" onclick="showNumber(this)">+</button></td> </tr> <tr> <td><button class="calculate" onclick="showNumber(this)">0</button></td> <td><button class="calculate" onclick="showNumber(this)">.</button></td> <td><button class="operate" onclick="showNumber(this)">/</button></td> <td><button class="operate" onclick="showAnswer()">=</button></td> </tr> </tbody> </table> </div> </body> </html> .css文件 table{ margin: 20px; padding: 1px; } th,input{ height: 120px; width: 410px; background-color:rgb(233, 232, 232); text-align: right; font-size: 40px; } button{ height: 100px; width: 100px; padding: 0px; font-size: 30px; } th,input,td,button{ border: 0px; } .calculate{ background-color: rgb(231, 231, 235); } .operate{ color: coral; } button:hover{ background-color: rgb(147, 241, 253); } .js文件 var result = new Array(); var ops = "+-*/"; function arrToStr(arr) { var strResult = ""; for (var i = 0; i < arr.length; i++) { strResult += arr[i]; } return strResult; } function showResult() { document.getElementById("result").value = arrToStr(result); } function showNumber(id) { var val = id.innerHTML; result.push(val); showResult(); } function showAnswer() { var answer = ""; var str = arrToStr(result); var midExpre = strToExpress(str); var suffixExpre = midToSuffix(midExpre); answer = suffixValue(suffixExpre); //console.log(midExpre); //console.log(suffixExpre); document.getElementById("result").value = str + "=" + answer; } function clearResult() { result = []; showResult(); } function clearOneResult() { result.pop(); showResult(); } function strToExpress(str) { var textArr = str.split(''); var newTextArr = []; var calTextArr = []; for (var i = 0; i < str.length; i++) { if (ops.indexOf(str[i]) != -1 ) { newTextArr.push("|", str[i], "|"); } else if (str[i] == '('){ newTextArr.push(str[i], "|"); } else if (str[i] == ')'){ newTextArr.push("|", str[i]); } else { newTextArr.push(textArr[i]); } } calTextArr = newTextArr.join('').split('|'); return calTextArr; } function midToSuffix(midExpre) { var opStack = []; var suffixExpre = []; for (var i = 0; i < midExpre.length; i++) { if (ops.indexOf(midExpre[i]) != -1 || midExpre[i] == '(' || midExpre[i] == ')' ) { if (midExpre[i] == '(' || opStack[opStack.length - 1] == '(') { opStack.push(midExpre[i]); } else if (midExpre[i] == ')') { do { suffixExpre.push(opStack.pop()); } while (opStack[opStack.length - 1] != '('); opStack.pop(); } else if (opStack.length == 0 || Priority(midExpre[i]) > Priority(opStack[opStack.length - 1])) { opStack.push(midExpre[i]); } else { do { suffixExpre.push(opStack.pop()); } while (opStack.length > 0 && Priority(midExpre[i]) <= Priority(opStack[opStack.length - 1])); opStack.push(midExpre[i]); } } else { suffixExpre.push(midExpre[i]); } } while (opStack.length > 0) { suffixExpre.push(opStack.pop()); } return suffixExpre; } function Priority(op) { var opPri = 0; switch (op) { case "+": opPri = 1; break; case "-": opPri = 1; break; case "*": opPri = 2; break; case "/": opPri = 2; break; } return opPri; } function suffixValue(suffixExpre) { var calStack = []; console.log(suffixExpre); for (var i = 0; i < suffixExpre.length; i++) { if (ops.indexOf(suffixExpre[i]) != -1) { var opRight = Number(calStack.pop()); var opLeft = Number(calStack.pop()); var tmpResult = 0; switch (suffixExpre[i]) { case '+': tmpResult = opLeft + opRight; break; case '-': tmpResult = opLeft - opRight; break; case '*': tmpResult = opLeft * opRight; break; case '/': tmpResult = opLeft / opRight; break; } calStack.push(tmpResult); } else { calStack.push(suffixExpre[i]); } console.log(calStack); } return calStack.pop(); } 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持极客世界。 |
请发表评论