Foro de elhacker.net

Programación => Desarrollo Web => Mensaje iniciado por: proteus8 en 5 Enero 2021, 23:55 pm



Título: llamar a función ajax al presionar tecla enter
Publicado por: proteus8 en 5 Enero 2021, 23:55 pm
Hola a todos!! tengo un problema con una función javascript, resulta que en mi pagina tengo un text y un botón, al presionar el botón se ejecuta la función javascript la que envía datos de un formulario a un controlador de laravel, esto funciona sin problemas , pero necesito que también se ejecute la función si el usuario presiona la tecla enter cuando esta en el text, no se como hacerlo ya que si ahora lo presiono me da un error indicando que envié valores vacíos a la función.

esta es mi función
Código
  1. function temporal(ruta)
  2. {
  3.   const codigobarra=$('#Txt_serie').val();
  4.   const sku_ext=$('#Txt_codigo').val();
  5.   const Idservicio=$('#Txt_servicio').val();
  6.   const Numguia=$('#Txt_numguia').val();
  7.   const Idmaterial=$('#Txt_idmaterial').val();
  8.   const Idproveedor=$('#Txt_prov').val();
  9.   const Numcantidad=$('#Txt_cant').val();
  10.   const identificador=$('#Txt_identificador').val();
  11.   const Numfila=$('#Txt_fila').val();
  12.   const usuario=$('#Txt_user').val();
  13.   const estado=1;
  14.  
  15.    $.ajax(
  16.        {
  17.            url:ruta,
  18.            type:'POST',
  19.            data: {
  20.                _token:$('input[name="_token"]').val(),
  21.                temp_mat_id:Idmaterial,
  22.                tem_mst_id:estado,
  23.                temp_ser_id:Idservicio,
  24.                temp_serie:codigobarra,
  25.                temp_guia:Numguia,
  26.                temp_pro_id:Idproveedor,
  27.                temp_identificador:identificador,
  28.                temp_nwa_id:1,
  29.                temp_use_id:usuario
  30.            },
  31.            success:function () {
  32.                           document.getElementById("respuesta").innerHTML=`<div class="alert alert-danger" role="alert">OK</div>`
  33.                  document.getElementById('Txt_serie').value= "";
  34.                  $('#Txt_serie').focus();
  35.                }
  36.  
  37.         });
  38.  
  39.         return false;
  40.  
  41.  
  42. }
  43.  

Código
  1. {{-- este el text que no logro que me funcione al presionar enter --}}
  2.  
  3. <input type="text" name="Txt_serie" id='Txt_serie' placeholder="0"  class="form-control">
  4.  
  5. {{-- este el tbotón que llama a la función--}}
  6.  
  7. <button name="Btn_agregar" id="Btn_agregar" type="button" onclick="temporal('{{ route('guiaingresos.insert') }}')"   class="btn btn-info">Agregar</button>
  8.  

espero me puedan ayudar.


Título: Re: llamar a función ajax al presionar tecla enter
Publicado por: EdePC en 6 Enero 2021, 01:07 am
Hay dos opciones, una es poner el tipo de botón a submit que es el estándar para formularios y reacciona al Enter enviando el formulario, entonces tendrías que quitarle ese evento onclick y pasárselo al evento onsubmit del formulario, ya que cuando una da click en el botón de tipo submit de un formulario o presiona Enter estando dentro de él, automáticamente se ejecuta el evento onsubmit del formulario. Pero para evitar que el formulario "se envíe", se actualice la página y te vacíe los datos, hay que poner un preventDefault() al final de la función:

Código
  1. <form onsubmit="myFunction()">
  2.  Enter name: <input type="text">
  3.  <input type="submit">
  4. </form>
  5.  
  6.  function myFunction() {
  7.    console.log('Hello')
  8.    event.preventDefault()
  9.  }

La otra forma es añadir el evento onkeyup o onkeypress al formulario o body para verificar si se a presionado el Enter y mandar a hacer lo mismo que hacia el onclick del botón. Me parece que había otra forma pero no la recuerdo bien XD


Título: Re: llamar a función ajax al presionar tecla enter
Publicado por: proteus8 en 6 Enero 2021, 01:46 am
@EdePC  excelente!!! funciono muchas gracias master.  ;-) ;-) ;-)