• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

544
Views
Problema con jquery_ujs: el girador animado Font Awesome funciona en Chrome pero no en Safari

Estoy usando font-awesome-rails en mi proyecto de rieles. Cuando el usuario hace clic en el botón Enviar en un formulario:

  • dentro del botón de envío debe haber una fuente giratoria animada, y el texto dentro del botón debe cambiar para decir "Enviando...".
  • el botón debe estar deshabilitado para que el usuario no pueda enviar el formulario varias veces.

El siguiente código funciona perfectamente cuando se usa Google Chrome:

 <%= f.button "Submit", class: "btn btn-success", data: {disable_with: "<i class='fa fa-spinner fa-spin'></i> Submitting..."} %>

En Safari sin embargo:

  • el botón se deshabilitó con éxito
  • Pero el ícono giratorio no aparece y el texto no cambia.

Creé una pequeña aplicación para mostrar el problema. El repositorio está aquí . Envíe el formulario del blog en Chrome y luego envíelo en Safari. Notarás que la animación funciona en Chrome pero no en Safari.

Vi este problema en jquery_ujs . Hay algunas soluciones alternativas bastante detalladas, pero nada que sea conveniente para su reutilización en todos los lugares en los que quiero implementar esta funcionalidad.

Parece ser un problema del navegador: algo como Safari no quiere hacer ningún procesamiento adicional una vez que se envía un formulario porque no quiere ralentizar las cosas.

Chris Oliver de GoRails me señaló que si ejecuta lo siguiente en la consola, incluso en Safari: desencadena el efecto deseado:

 $.rails.disableFormElement($("button"))

Entonces el efecto funciona en safari. Simplemente no funciona cuando está vinculado a un botón de envío de formulario. He intentado hacer esto con la versión 9.1.2 de Safari, así como con la 10.0.1. También lo he intentado en Rails 4.2.6 y Rails 5.

about 3 years ago · Santiago Trujillo
1 answers
Answer question

0

Puede que haya una buena solución rápida... Vea este JSFiddle , que es un ejemplo mínimo aún más pequeño del problema. En Safari 10.1, la actualización se interrumpe aproximadamente el 70% del tiempo para mí.

Luego forzamos el uso de aceleración por hardware, a través de CSS:

 form { -webkit-transform: translate3d(0,0,0); transform: translateZ(0); }

Y el problema desaparece .

Nota: técnicamente, la primera línea de CSS debería ser suficiente para forzar la aceleración del hardware, pero definitivamente se necesita la segunda línea aquí para que esto funcione...

about 3 years ago · Santiago Trujillo Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error