• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

167
Vistas
js setTimeout () finaliza instantáneamente sin ningún descanso

al codificar, me encontré con este problema muy extraño. Mi código está a continuación: js

 document.getElementById("id").style.width = "0%" var a = 0; setTimeout(function () { if (a <= 60) { document.getElementById("id").style.width = a + "%"; a++; } }, 100);

Quiero que se ejecute 60 veces, cada vez cambiando el ancho del div en un 1%. Sin embargo, cuando ejecuto el código, el bloque if hace que finalice instantáneamente como si el tiempo de espera no funcionara. ¿Alguien puede decirme qué está mal? ¡Gracias por adelantado!

almost 3 years ago · Juan Pablo Isaza
1 Respuestas
Responde la pregunta

0

La función setTimeout se ejecuta solo una vez después de ese tiempo especificado en milisegundos.

Si desea seguir ejecutando el bloque, debe utilizar setInterval en lugar de setTimeout .

setInterval continúa llamando a la función desde que se borra el intervalo.

No olvides llamar a clearInterval una vez que alcances el objetivo.

 var a = 0; const interval = setInterval(function () { if (a <= 60) { console.log("Im being called"); document.getElementById("id").style.width = a + "%"; a++; } else { // Target achieved, clearing interval console.log("Im stoping execution"); clearInterval(interval) } }, 100);
 #id { height: 300px; background: orange; }
 <div id="id"></div>

almost 3 years ago · Juan Pablo Isaza Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda