zoukankan      html  css  js  c++  java
  • js计算器---转

    至今见过的一个还没问题的计算器,收藏在此.

    转自javascript写的简单的计算器原文链接,谢分享!

    js部分

     1 ar num=0,result=0,numshow="0"; 
     2 var operate=0; //判断输入状态的标志 
     3 var calcul=0; //判断计算状态的标志 
     4 var quit=0; //防止重复按键的标志 
     5 function command(num){ 
     6 var str=String(document.calculator.numScreen.value); //获得当前显示数据 
     7 str=(str!="0") ? ((operate==0) ? str : "") : ""; //如果当前值不是"0",且状态为0,则返回当前值,否则返回空值; 
     8 str=str + String(num); //给当前值追加字符 
     9 document.calculator.numScreen.value=str; //刷新显示 
    10 operate=0; //重置输入状态 
    11 quit=0; //重置防止重复按键的标志 
    12 } 
    13 function dzero(){ 
    14 var str=String(document.calculator.numScreen.value); 
    15 str=(str!="0") ? ((operate==0) ? str + "00" : "0") : "0"; //如果当前值不是"0",且状态为0,则返回当str+"00",否则返回"0"; 
    16 document.calculator.numScreen.value=str; 
    17 operate=0; 
    18 } 
    19 function dot(){ 
    20 var str=String(document.calculator.numScreen.value); 
    21 str=(str!="0") ? ((operate==0) ? str : "0") : "0"; //如果当前值不是"0",且状态为0,则返回当前值,否则返回"0"; 
    22 for(i=0; i<=str.length;i++){ //判断是否已经有一个点号 
    23 if(str.substr(i,1)==".") return false; //如果有则不再插入 
    24 } 
    25 str=str + "."; 
    26 document.calculator.numScreen.value=str; 
    27 operate=0; 
    28 } 
    29 function del(){ //退格 
    30 var str=String(document.calculator.numScreen.value); 
    31 str=(str!="0") ? str : ""; 
    32 str=str.substr(0,str.length-1); 
    33 str=(str!="") ? str : "0"; 
    34 document.calculator.numScreen.value=str; 
    35 } 
    36 function clearscreen(){ //清除数据 
    37 num=0; 
    38 result=0; 
    39 numshow="0"; 
    40 document.calculator.numScreen.value="0"; 
    41 } 
    42 function plus(){ //加法 
    43 calculate(); //调用计算函数 
    44 operate=1; //更改输入状态 
    45 calcul=1; //更改计算状态为加 
    46 } 
    47 function minus(){ //减法 
    48 calculate(); 
    49 operate=1; 
    50 calcul=2; 
    51 } 
    52 function times(){ //乘法 
    53 calculate(); 
    54 operate=1; 
    55 calcul=3; 
    56 } 
    57 function divide(){ //除法 
    58 calculate(); 
    59 operate=1; 
    60 calcul=4; 
    61 } 
    62 function persent(){ //求余 
    63 calculate(); 
    64 operate=1; 
    65 calcul=5; 
    66 } 
    67 function equal(){ 
    68 calculate(); //等于 
    69 operate=1; 
    70 num=0; 
    71 result=0; 
    72 numshow="0"; 
    73 } 
    74 // 
    75 function calculate(){ 
    76 numshow=Number(document.calculator.numScreen.value); 
    77 if(num!=0 && quit!=1){ //判断前一个运算数是否为零以及防重复按键的状态 
    78 switch(calcul){ //判断要输入状态 
    79 case 1:result=num+numshow;break; //计算"+" 
    80 case 2:result=num-numshow;break; //计算"-" 
    81 case 3:result=num*numshow;break; 
    82 case 4:if(numshow!=0){result=num/numshow;}else{document.getElementById("note").innerHTML="被除数不能为零!"; setTimeout(clearnote,4000)} break; 
    83 case 5:result=num%numshow;break; 
    84 } 
    85 quit=1; //避免重复按键 
    86 } 
    87 else{ 
    88 result=numshow; 
    89 } 
    90 numshow=String(result); 
    91 document.calculator.numScreen.value=numshow; 
    92 num=result; //存储当前值 
    93 } 
    94 function clearnote(){ //清空提示 
    95 document.getElementById("note").innerHTML=""; 
    96 } 
    View Code

    html部分

     1 <body> 
     2 <div id="calculator"> 
     3 <div id="calcu-head"><span class="imyeah">© <a href="http://www.cnblogs.com/imyeah/" target="_blank">I'm Yeah!</a></span><h6>简单的计算器</h6></div> 
     4 <form name="calculator" action="" method="get"> 
     5 <div id="calcu-screen"> 
     6 <!--配置显示窗口,使用onfocus="this.blur();"避免键盘输入--> 
     7 <input type="text" name="numScreen" class="screen" value="0" onfocus="this.blur();" /> 
     8 </div> 
     9 <div id="calcu-btn"> 
    10 <ul> <!--配置按钮--> 
    11 <li onclick="command(7)">7</li> 
    12 <li onclick="command(8)">8</li> 
    13 <li onclick="command(9)">9</li> 
    14 <li class="tool" onclick="del()"></li> 
    15 <li class="tool" onclick="clearscreen()">C</li> 
    16 <li onclick="command(4)">4</li> 
    17 <li onclick="command(5)">5</li> 
    18 <li onclick="command(6)">6</li> 
    19 <li class="tool" onclick="times()">×</li> 
    20 <li class="tool" onclick="divide()">÷</li> 
    21 <li onclick="command(1)">1</li> 
    22 <li onclick="command(2)">2</li> 
    23 <li onclick="command(3)">3</li> 
    24 <li class="tool" onclick="plus()">+</li> 
    25 <li class="tool" onclick="minus()">-</li> 
    26 <li onclick="command(0)">0</li> 
    27 <li onclick="dzero()">00</li> 
    28 <li onclick="dot()">.</li> 
    29 <li class="tool" onclick="persent()">%</li> 
    30 <li class="tool" onclick="equal()">=</li> 
    31 </ul> 
    32 </div> 
    33 <div id="calcu-foot"> 
    34 <span id="note"></span> 
    35 <span class="welcome">欢迎使用javascript计算器!<a href="http://www.cnblogs.com/imyeah" target="_blank">反馈</a></span> 
    36 </div> 
    37 </form> 
    38 </div> 
    39 </body> 
    View Code

    css部分

      1 body { 
      2 font-size:12px; 
      3 font-family:Arial, Georgia, "Times New Roman", Times, serif; 
      4 color:#555; 
      5 text-align:center; 
      6 background-color:#e2e2e2; 
      7 } 
      8 h6{ 
      9 margin:0; 
     10 font-size:12px; 
     11 } 
     12 #calculator { 
     13 width:240px; 
     14 height:auto; 
     15 overflow:hidden; 
     16 margin:10px auto; 
     17 border:#fff 1px solid; 
     18 padding-bottom:10px; 
     19 background-color:#f2f2f2; 
     20 } 
     21 #calculator div { 
     22 clear:both; 
     23 } 
     24 #calculator ul{ 
     25 padding:0; 
     26 margin:5px 14px; 
     27 border:#fff 1px solid; 
     28 height:auto; 
     29 overflow:hidden 
     30 } 
     31 #calculator li{ 
     32 list-style:none; 
     33 float:left; 
     34 width:32px; 
     35 height:32px; 
     36 margin:5px; 
     37 display:inline; 
     38 line-height:32px; 
     39 font-size:14px; 
     40 background-color:#eaeaea; 
     41 } 
     42 #calculator li.tool{ 
     43 background-color:#e2e2e2; 
     44 } 
     45 #calculator li:hover{ 
     46 background-color:#f9f9f9; 
     47 cursor:pointer; 
     48 } 
     49 #calculator li:active{ 
     50 background-color:#fc0; 
     51 cursor:pointer; 
     52 } 
     53 #calculator li.tool:active{ 
     54 background-color:#d8e8ff; 
     55 cursor:pointer; 
     56 } 
     57 #calcu-head { 
     58 text-align:left; 
     59 padding:10px 15px 5px; 
     60 } 
     61 span.imyeah { 
     62 float:right; 
     63 color:#ccc; 
     64 } 
     65 span.imyeah a{ 
     66 color:#ccc; 
     67 } 
     68 .screen{ 
     69 width:200px; 
     70 height:24px; 
     71 line-height:24px; 
     72 padding:4px; 
     73 border:#e6e6e6 1px solid; 
     74 border-bottom:#f2f2f2 1px solid; 
     75 border-right:#f2f2f2 1px solid; 
     76 margin:10px auto; 
     77 direction:ltr; 
     78 text-align:right; 
     79 font-size:16px; 
     80 color:#999; 
     81 } 
     82 #calcu-foot{ 
     83 text-align:left; 
     84 padding:10px 15px 5px; 
     85 height:auto; 
     86 overflow:hidden; 
     87 } 
     88 span#note{ 
     89 float:left; 
     90 width:210px; 
     91 height:auto; 
     92 overflow:hidden; 
     93 color:red; 
     94 } 
     95 span.welcome{ 
     96 clear:both; 
     97 color:#999; 
     98 } 
     99 span.welcome a{ 
    100 float:right; 
    101 color:#999; 
    102 }
    View Code
  • 相关阅读:
    openssl生成公钥私钥对 加解密
    boost replace_if replace_all_regex_copy用法
    PS 图像滤镜— — USM 锐化
    使用boost库生成 随机数 随机字符串
    改动Android设备信息,如改动手机型号为iPhone7黄金土豪版!
    验证(Verification)与确认(Validation)的差别
    Spring-SpringMVC-Hibernate整合
    全面整理的C++面试题
    Metropolis Hasting算法
    捕捉到来自宇宙深空的神奇X-射线信号
  • 原文地址:https://www.cnblogs.com/wangduojing/p/8037630.html
Copyright © 2011-2022 走看看