频道栏目
首页 > 资讯 > HTML/CSS > 正文

采用jquery实现简单的计算器

17-06-20        来源:[db:作者]  
收藏   我要投稿

实现的原理只要是利用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{
                width: 300px;
                padding-top: 12px;
                margin: 0 auto;
            }
            td{
                border: 1px grey solid;
                width: 54px;
                height: 54px;
                text-align: center;
                background-color: #00FFFF;
                color: #0074D9;
                font-size: 24px;
                font-weight: bold;
            }
            #input{
                width: 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   " onclick="getNum(1)"></td>
            <td><input type="button" value="  2   " onclick="getNum(2)"></td>
            <td><input type="button" value="  3   " onclick="getNum(3)"></td>
            <td><input type="button" value="  +   " onclick="getNum('+')"></td>
          </tr>
          <tr>
            <td><input type="button" value="  4   " onclick="getNum(4)"></td>
            <td><input type="button" value="  5   " onclick="getNum(5)"></td>
            <td><input type="button" value="  6   " onclick="getNum(6)"></td>
            <td><input type="button" value="  -   " onclick="getNum('-')"></td>
          </tr>
          <tr>
            <td><input type="button" value="  7   " onclick="getNum(7)"></td>
            <td><input type="button" value="  8   " onclick="getNum(8)"></td>
            <td><input type="button" value="  9   " onclick="getNum(9)"></td>
            <td><input type="button" value="  *   " onclick="getNum('*')"></td>
          </tr>
          <tr>
            <td><input type="button" value="  0   " onclick="getNum(0)"></td>
            <td><input type="button" value="  00   " onclick="getNum('00')"></td>
            <td><input type="button" value="  .   " onclick="getNum('.')"></td>
            <td><input type="button" value="  /   " onclick="getNum('/')"></td>
          </tr>
          <tr>
            <td><input type="button" value="  (   " onclick="getNum('(')"></td>
            <td><input type="button" value="  )   " onclick="getNum(')')"></td>
            <td><input type="button" value="  %   " onclick="getNum('%')"></td>
            <td><input type="button" value="  =   " onclick="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>特别说明



特别说明

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

相关TAG标签
上一篇:51nod 1222 最小公倍数计数
下一篇:call()和apply()的作用和区别
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站