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

0

161
Views
¿Cómo administro los intervalos con los controladores de eventos en React JS?

Estoy aprendiendo React JS y comencé a construir un reloj Pomodoro. No entiendo cómo iniciar un intervalo específico al hacer clic en un botón y detener el temporizador al hacer clic en un botón separado. Cuando hago clic en "reproducir", el temporizador se detiene a las 24:059. Cuando hago clic en el mismo botón, va a 24:058 y vuelve a 24:059 y luego se repite. Cuando vuelvo a hacer clic, pasa a 24:057, etc.

Cuando elimino la condición de switch(seconds) en decreaseTimer() y simplemente inserto setSeconds((seconds) => seconds - 1); los segundos disminuyen en 1 como se esperaba. ¿Cómo soluciono este problema? Agradezco toda la ayuda y los consejos aquí. ¡Gracias!

PomoTimer.js

 import { useEffect, useState } from "react"; const PomoTimer = (props) => { const [seconds, setSeconds] = useState(0); const [intervalId, setIntervalId] = useState(""); const [isSession, setSession] = useState(true); const startTimer = () => { let newIntervalId = setInterval(decreaseTimer, 1000); setIntervalId((intervalId) => newIntervalId); }; const stopTimer = () => { clearInterval(intervalId); }; const decreaseTimer = () => { switch (seconds) { case 0: props.onTimerMinuteChange(props.timerMinute - 1); setSeconds((seconds) => 59); break; default: setSeconds((seconds) => seconds - 1); break; } }; const resetTimer = () => { clearInterval(intervalId); props.resetTimer(); props.onPlayChange(false); setSeconds(0); }; return ( <section> <section> {/* <h4>{session === true ? "Session" : "Break"}</h4> */} <span>{props.timerMinute}</span> <span>:</span> <span>{seconds === 0 ? "00" : "0" + seconds}</span> </section> <section> <button onClick={startTimer}>Play</button> <button onClick={stopTimer}>Stop</button> <button onClick={resetTimer}>Refresh</button> </section> </section> ); }; export default PomoTimer;
about 3 years ago · Juan Pablo Isaza
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