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

0

157
Views
React console.log se ejecuta una vez en render, pero ¿el efecto secundario ocurre dos veces? ¿Modo estricto?

Sé que esto está ocurriendo debido a React.StrictMode, pero estoy muy confundido sobre cómo está ocurriendo exactamente este comportamiento.

Básicamente, tengo un componente muy simple, que registra cada vez que se procesa y también incrementa un contador global cuando lo hace.

 let logCount = 0; function App() { const [count, setCount] = React.useState(0); const incrementCount = React.useCallback(() => setCount(count + 1), [count]); console.log(logCount++, Math.random()); return ( <div> {count} <button onClick={incrementCount}>rerender me!</button> </div> ); } ReactDOM.render( <React.StrictMode> <App /> </React.StrictMode>, document.querySelector("#root") );
 <script crossorigin src="https://unpkg.com/react@16/umd/react.development.js"></script> <script crossorigin src="https://unpkg.com/react-dom@16/umd/react-dom.development.js"></script> <div id="root"></div>

Cada vez que se vuelve a renderizar el componente, solo veo un archivo console.log, pero logCount se habrá incrementado dos veces . Si apago React.StrictMode, solo se habrá incrementado una vez.

En su mayoría, tengo curiosidad si reaccionar tiene alguna lógica especial para garantizar que las declaraciones de console.log y similares solo se ejecuten una sola vez, incluso en modo estricto. Si no, tengo aún más curiosidad por lo que me estoy perdiendo aquí. Agregué una llamada Math.random() como control de cordura.

over 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