zoukankan      html  css  js  c++  java
  • 采用jquery实现简单的计算器

    实现的原理只要是利用jquery eval(string)函数对字符串的计算。

    string:必需。要计算的字符串,其中含有要计算的 JavaScript 表达式或要执行的语句。

    返回值

    通过计算 string 得到的值(如果有的话)。

    说明

    该方法只接受原始字符串作为参数,如果 string 参数不是原始字符串,那么该方法将不作任何改变地返回。因此请不要为 eval() 函数传递 String 对象来作为参数。

    如果试图覆盖 eval 属性或把 eval() 方法赋予另一个属性,并通过该属性调用它,则 ECMAScript 实现允许抛出一个 EvalError 异常。

    抛出

    如果参数中没有合法的表达式和语句,则抛出 SyntaxError 异常。

    如果非法调用 eval(),则抛出 EvalError 异常。

    如果传递给 eval() 的 Javascript 代码生成了一个异常,eval() 将把该异常传递给调用者

    <!DOCTYPE html>
    <html>
    	<head>
    		<meta charset="UTF-8">
    		<title>计算器</title>
    		<link href="bootstrap-3.3.0/dist/css/bootstrap-theme.min.css" />
    		<style>
    			*{
    				padding: 0;margin: 0;
    			}
    			#maxbox{
    				 300px;
    				padding-top: 12px;
    				margin: 0 auto;
    			}
    			td{
    				border: 1px grey solid;
    				 54px;
    				height: 54px;
    				text-align: center;
    				background-color: #00FFFF;
    				color: #0074D9;
    				font-size: 24px;
    				font-weight: bold;
    			}
    			#input{
    				 286px;
    				height: 32px;
    				margin-left: 2px;
    				font-size: 14px;
    				font-weight: bold;
    			}
    		</style>
    	</head>
    	<body>
    		<table width="200" border="1" cellpadding="2">
    		  <tr>
    		    <td colspan="4"><input type="text" name="result" id="result" size="33"></td>
    		  </tr>
    		  <tr>
    		    <td><input type="button" value="  1   " οnclick="getNum(1)"></td>
    		    <td><input type="button" value="  2   " οnclick="getNum(2)"></td>
    		    <td><input type="button" value="  3   " οnclick="getNum(3)"></td>
    		    <td><input type="button" value="  +   " οnclick="getNum('+')"></td>
    		  </tr>
    		  <tr>
    		    <td><input type="button" value="  4   " οnclick="getNum(4)"></td>
    		    <td><input type="button" value="  5   " οnclick="getNum(5)"></td>
    		    <td><input type="button" value="  6   " οnclick="getNum(6)"></td>
    		    <td><input type="button" value="  -   " οnclick="getNum('-')"></td>
    		  </tr>
    		  <tr>
    		    <td><input type="button" value="  7   " οnclick="getNum(7)"></td>
    		    <td><input type="button" value="  8   " οnclick="getNum(8)"></td>
    		    <td><input type="button" value="  9   " οnclick="getNum(9)"></td>
    		    <td><input type="button" value="  *   " οnclick="getNum('*')"></td>
    		  </tr>
    		  <tr>
    		    <td><input type="button" value="  0   " οnclick="getNum(0)"></td>
    		    <td><input type="button" value="  00   " οnclick="getNum('00')"></td>
    		    <td><input type="button" value="  .   " οnclick="getNum('.')"></td>
    		    <td><input type="button" value="  /   " οnclick="getNum('/')"></td>
    		  </tr>
    		  <tr>
    		    <td><input type="button" value="  (   " οnclick="getNum('(')"></td>
    		    <td><input type="button" value="  )   " οnclick="getNum(')')"></td>
    		    <td><input type="button" value="  %   " οnclick="getNum('%')"></td>
    		    <td><input type="button" value="  =   " οnclick="getResult()"></td>
    		  </tr>
    		</table>
    		<script language="javascript" type="text/javascript">
    			 var cleartext=false;//设置标识值
    			 function getNum(num){
    			 //alert(num);
    			  var result=document.getElementById("result");
    			  if(cleartext){
    			   result.value="";
    			   cleartext=false;
    			  }
    			 result.value+=num;
    			 }
    			function getResult(){
    			 var result=document.getElementById("result");
    			 result.value=result.value+"="+eval(result.value);
    			 cleartext=true;//计算结果后改变标识
    			}
    		</script>
    	</body>
    </html>特别说明

    特别说明:在实现计算表达式的时候一定要注意计算表达式的为合法表达式,异常请参考上面的抛出部分

    界面展示以及结果展示


  • 相关阅读:
    【Cocos2d-X游戏实战开发】捕鱼达人之游戏场景的创建(六)
    WPF-24:绘制正多边形
    长假引起的系统审批流的变更的思考
    Linux shell编程02 shell程序的执行 及文件权限
    poj2787 算24
    REVERSE关键字之REVERSE索引
    设计模式读书笔记-----备忘录模式
    乔布斯的基本原则 (斯卡利访谈录 )
    MediaInfo源代码分析 1:整体结构
    Python 入门教程 9 ---- A Day at the Supermarket
  • 原文地址:https://www.cnblogs.com/cqxhl/p/12993325.html
Copyright © 2011-2022 走看看