1
        2
        3
        4
        5
        6
        7
        8
        9
       10
       11
       12
       13
       14
       15
       16
       17
       18
       19
       20
       21
       22
       23
       24
       25
       26
       27
       28
       29
       30
       31
       32
       33
       34
       35
       36
       37
       38
       39
       40
       41
       42
       43
       44
       45
       46
       47
       48
       49
       50
       51
       52
       53
       54
       55
       56
       57
       58
       59
       60
       61
       62
       63
       64
       65
       66
       67
       68
       69
       70
       71
       72
       73
       74
       75
       76
       77
       78
       79
       80
       81
       82
       83
       84
       85
       86
       87
       88
       89
       90
       91
       92
       93
       94
       95
       96
       97
       98
       99
      100
      101
      102
      103
      104
      105
      106
      107
      108
      109
      110
      111
      112
      113
      114
      115
      116
      117
      118
      119
      120
      121
      122
      123
      124
      125
      126
      127
      128
      129
      130
      131
      132
      133
      134
      135
      136
      137
      138
      139
      140
      141
      142
      143
      144
      145
      146
      147
      148
      149
      150
      151
      152
      153
      154
      155
      156
      157
      158
      159
      160
      161
      162
      163
      164
      165
      166
      167
      168
      169
      170
      171
      172
      173
      174
      175
      176
      177
      178
      179
      180
      181
      182
      183
      184
      185
      186
      187
      188
      189
      190
      191
      192
      193
      194
      195
      196
      197
      198
      199
      200
      201
      202
      203
      204
      205
      206
      207
      208
      209
      210
      211
      212
      213
      214
      215
      216
      217
      218
      219
      220
      221
      222
      223
      224
      225
<!DOCTYPE html>
      <html lang="es">
      <head>
          <meta charset="UTF-8">
          <meta name="viewport" content="width=device-width, initial-scale=1.0">
          <meta http-equiv="X-UA-Compatible" content="ie=edge">
          <title>Calculadora</title>
          <!-- ENLACE GOOGLEFONT-->
          <link href="https://fonts.googleapis.com/css?family=Yanone+Kaffeesatz" rel="stylesheet"> 
          <!-- ENLACE CSS-->
          <link rel="stylesheet" type="text/css" href="estilos.css">
          <!-- ENLACE BOOTSTRAP-->
          <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">
          <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous"></script>
          <!-- ENLACE JQUERY-->
          <script src="jquery-3.4.1.min.js" type="text/javascript"></script>
      
          <script type="text/javascript">
           
          $(document).ready(function(){ 
          /**************************************************/
          // OPERACIONES UNITARIAS ( CON UN SOLO OPERANDO )
          var num, acc = 0, op ="";
      
      
                  $(function() {
                  $("#n1").on("click",  
                  function(){ $("#n1").val("");}
                  );
      
                  // 1.1) NÚMERO ELEVADO AL CUADRADO
                  $("#b1").on("click", 
                  function() {
                  var num = $("#n1");
                  num.val(num.val() * num.val());
                  }
                  );
                  });
                  //1.2)  INVERSO DE UN NÚMERO
                  $("#inverso").on("click",
                  function(){
                      var num =$("#n1");
                      num.val( 1 / num.val() );
                  });
                  //1.3) RAÍZ CUADRADA DE UN NÚMERO
                  $("#cuadrada").on("click",
                  function(){
                      var num =$("#n1");
                      num.val( Math.sqrt(num.val()) );
                  });
                  //1.4) PARTE ENTERA DE UN NÚMERO
                  /*
                  parte entera de x: si x es positivo devuelve Math.floor(x) 
                  y si es negativo devuelve Math.ceil(x)
                  Math.floor : Devuelve el máximo entero menor o igual a un número
                  Math.ceil : devuelve el entero más pequeño mayor o igual a un número dado
                  */
                  $("#entera").on("click",
                  function(){
                      var num =$("#n1");
                      //SI VARIABLE num ES  >= QUE CERO, EJECUTA Math.floor
                      if(num.val() >= 0){
                      num.val( Math.floor(num.val()) );
                      }
                      // SI NO, EJECUTA Math.ceil
                      else{
                      num.val( Math.ceil(num.val()) );
                      }    
                  });
                  //1.5) POTENCIA N DEL NÚMERO 2
                  $("#potencia").on("click",
                  function(){
                      var num =$("#n1");
                      var num2 = 2;
                      num.val( Math.pow(num2,num.val()) );
                  });
                  //1.6) FACTORIAL  DEL NÚMERO
                  $("#factorial").on("click",
                  function(){
                      var num =$("#n1");
                      var resultado = 1;
                      for(var i=1; i<= +num.val(); i++) { 
                                  resultado *= i
                          }
                          num.val(resultado);
                  });
          /**************************************************/
          // OPERACIONES BINARIAS ( CON DOS OPERANDOS )
       
        //SUMA
        $("#suma").on("click", 
          function() {
            acc = $("#n1").val();
            op = "+";
          }
        );
        //RESTA
        $("#resta").on("click", 
          function() {
            acc = $("#n1").val();
            op = "-";
          }
        );
        //MULTIPLICA
        $("#multiplica").on("click", 
          function() {
            acc = $("#n1").val();
            op = "*";
          }
        );
        //DIVIDE
        $("#divide").on("click", 
          function() {
            acc = $("#n1").val();
            op = "/";
          }
        );
        //x ELEVADO A y
        $("#elevado").on("click", 
          function() {
            acc = $("#n1").val();
            op = "e";
          }
        );
      
        $("#calcular").on("click", 
          function() {
            num = $("#n1").val();
            //COMPARA LO QUE ESTA EN op Y EJECUTA OPERACION MATEMATICA
            switch(op){
                  case '+':
                        {num = +acc + +num;$("#n1").val(num);}
                        break
                  case '-':
                        {num = +acc - num;$("#n1").val(num);}
                        break
                  case '*':
                        {num = +acc * num;$("#n1").val(num);}
                        break
                  case '/':
                        {num = +acc / num;$("#n1").val(num);}
                        break
                  case 'e':
                        {num = Math.pow(+acc,num);$("#n1").val(num);}
                        break
            } 
          }); 
        /* ******************************************************* */
          //OPERACIONES CON OPERANDOS EN FORMATO CSV
      
           //SUMATORIO X (SUMATORIO DE N NUMEROS)
        $("#sumatorio").on("click", 
          function() {
              num = $("#n1").val();
              
            var z = num;// LA CADENA SE ALMACENA EN z
            var array = z.split(",");//CONVIERTE z EN ARRAY SEPARADO CON ,
            var sumatorio = 0;
            //RECORRE Y SUMA ELEMENTOS EN ARRAY
            $.each( array, function( index, value ){
                sumatorio += parseInt(value);
            });
            $("#n1").val(sumatorio);
       
          });
          //PRODUCTO X (PRODUCTO DE N NÚMEROS)
          $("#producto").on("click", 
          function() {
            num = $("#n1").val();
            //Convertimos la cadena en array, separado por la coma
            var z = num;// LA CADENA SE ALMACENA EN z
            var array = z.split(",");//CONVIERTE z EN ARRAY SEPARADO CON ,
            var producto = 1;
            //RECORRE Y SUMA ELEMENTOS EN ARRAY
            $.each( array, function( index, value ){
                producto = producto * parseInt(value);
            });
            $("#n1").val(producto);
          });
      
      
          });  
        
           </script>
      
      </head>
      <body>
        <div class="encabezado">
        <p><h1>Buenos días, bienvenido a la calculadora de Luis Serrat.</h1></p>
        </div>
        <div class="calculadora">
          Número:
        <input type="text" id="n1"><br>
        Operaciones unitarias: <br>
        <button id="b1" class="btn btn-danger"> x<sup>2</sup> </button>
        <button id="inverso" class="btn btn-danger"> Inverso </button>
        <button id="cuadrada" class="btn btn-danger"> Raiz cuadrada </button><br><br>
        <button id="entera" class="btn btn-danger"> Parte entera </button>
        <button id="potencia" class="btn btn-danger"> 2^n</button>
        <button id="factorial" class="btn btn-danger"> Factorial</button><br><br>
      
        Operaciones binarias:<br>
        <button id="suma" class="btn btn-danger"> Suma</button>
        <button id="resta" class="btn btn-danger"> Resta</button>
        <button id="multiplica" class="btn btn-danger"> Multiplica</button><br><br>
        <button id="divide" class="btn btn-danger"> Divide</button>
        <button id="elevado" class="btn btn-danger"> x&#94;y</button>
        <button id="calcular" class="btn btn-danger"> =</button><br><br>
        
        Operaciones formato csv<br>
        Sumatorio de n números<br>
        <button id="sumatorio" class="btn btn-danger"> &#931; x</button><br>
        Producto de n números<br>
        <button id="producto" class="btn btn-danger">&Pi; x</button>
      </div><br><br>
      <h3>Ver codigo fuente de esta pagina: 
          <figure>
              <a href="codigo.html">
                  <img src="rocket.png" width="56" height="56">
              </a>
          </figure>
      </h3>
        
      </body>
      </html>