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

0

129
Views
No entiendo cómo se ejecuta mi código jQuery. ¿Cómo lograr la animación requerida?

Aquí está el código

 https://jsfiddle.net/zdu1efrj/
 $(document).ready( function() { // start box animation code let animatedBox = $('.box'); animatedBox.css('backgound', 'red'); animatedBox.animate( { left: '500px', height: '250px', width: '250px' }, 1000); animatedBox.css('background', 'blue'); animatedBox.animate( { top: '500px', height: '100px', width: '100px' }, 1000); // end box animation code });

Quiero que el cuadro en la animación sea rojo siempre que se mueva verticalmente, luego cambie su color a azul y se mueva hacia abajo.

¿Por qué el código no se ejecuta en secuencia?

por animatedBox.css('background', 'blue'); parece ser ejecutado antes de la finalización de

 animatedBox.animate( { left: '500px', height: '250px', width: '250px' }, 1000);``` ?
almost 3 years ago · Juan Pablo Isaza
1 answers
Answer question

0

El problema aquí es que la llamada animate() es asincrónica, ya que las acciones se colocan en una cola y se ejecutan más tarde. Sin embargo, las llamadas css() no están en cola/asincrónicas y, por lo tanto, se ejecutan de inmediato.

Para solucionar esto, use el argumento de devolución de llamada del método animate() para que cambie el color del elemento después de que se complete la primera secuencia de animación:

 animatedBox.animate({ left: '500px', height: '250px', width: '250px' }, 1000, function() { animatedBox.css('background', 'blue'); });

Sin embargo, todo esto se puede lograr de manera mucho más efectiva y con mucho más rendimiento utilizando solo CSS:

 body { position: relative; } .box { position: absolute; left: 0; top: 0; width: 100px; height: 100px; position: absolute; background-color: red; animation: box-movement 2s forwards; } @keyframes box-movement { 50% { left: 500px; top: 0; height: 250px; width: 250px; background-color: red; } 100% { left: 500px; top: 500px; height: 100px; width: 100px; background-color: blue; } }
 <div class="box"></div>

almost 3 years ago · Juan Pablo Isaza 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