Home Web Front-end JS Tutorial React: How Often Does a Cleanup Function Run?

React: How Often Does a Cleanup Function Run?

Nov 01, 2024 pm 12:50 PM

React: How Often Does a Cleanup Function Run?

React components with state variables trigger a re-render when those variables are updated. This is expected and is one of React's core features. Additionally, components offer a cleanup function, which is triggered every time the component is "unmounted." But how often does this cleanup function actually run?

Well, as we’ll explore in this demo, the cleanup function can have multiple triggers, but a common one is updates to a state variable when it’s linked to a side effect.

In short, if your React component is using useEffect and follows a specific state variable, let's look at the following example:

useEffect(() => {
  console.log("Page mounted");

  return () => {
    // cleanup function
    console.log("Page unmounted");
  };
}, [counter]);

The cleanup function will be called every time counter is updated.

When a state variable is updated, React re-renders the component, which means it first needs to "remove" it and then "render" it again. While the virtual DOM optimizes which nodes need updating, at the logic level, the cleanup function still gets called.

In most cases, this is fine and expected. However, if your cleanup function is doing things like reporting events, removing listeners, etc., make sure that’s intentional, since the cleanup function will be called multiple times based on the state variable.

Demo

Let's see a demo.

  • In the developer tools, open the console.
  • You will notice two logs:
Child mounted
Page mounted

React: How Often Does a Cleanup Function Run?

That means both components, Page and Child, were rendered.

  • If you remember the snippet shared above, useEffect is tied to counter, which is incremented when clicking the first button. Right now, it should say: Increment 0. Let's go ahead and click it.

  • Keep an eye on the Console and notice how four logs were added:

Child unmounted
Page unmounted
Child mounted
Page mounted

React: How Often Does a Cleanup Function Run?

The state variable counter got updated, and since there are two useEffect hooks tied to counter, it means their cleanup functions were executed. Notice how, for the Page component, useEffect is tied to the state variable, while for the Child component, the side effect is tied to a prop variable, where the source is still the same counter state variable.

Additionally, you can see the button Flag Off, which updates another state variable that is not linked to useEffect. This means that clicks on this button won't trigger the cleanup function.

Conclusion

Cleanup functions are heavily used in React, especially to report things once the component is "done." However, be cautious about tying the useEffect to a state variable. As seen in the demo, this causes the cleanup function to be called every time the state variable is updated, which might not be expected.

Most of the time, the cleanup function is housed in a useEffect without any state variables.

useEffect(() => {
  console.log("Page mounted");

  return () => {
    // cleanup function
    console.log("Page unmounted");
  };
}, [counter]);

It's fine to have multiple useEffect hooks in one component. In this case, you could have one that reacts to a state variable and another to set the cleanup function.

Child mounted
Page mounted

To answer the question, the cleanup function will be called when the component is unmounted. This could happen when the user navigates to another section of the app, or if useEffect depends on a state variable, then it will be called N times whenever that state variable is updated.

The above is the detailed content of React: How Often Does a Cleanup Function Run?. For more information, please follow other related articles on the PHP Chinese website!

Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn

Hot AI Tools

Undress AI Tool

Undress AI Tool

Undress images for free

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

ArtGPT

ArtGPT

AI image generator for creative art from text prompts.

Stock Market GPT

Stock Market GPT

AI powered investment research for smarter decisions

Hot Tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 Chinese version

SublimeText3 Chinese version

Chinese version, very easy to use

Zend Studio 13.0.1

Zend Studio 13.0.1

Powerful PHP integrated development environment

Dreamweaver CS6

Dreamweaver CS6

Visual web development tools

SublimeText3 Mac version

SublimeText3 Mac version

God-level code editing software (SublimeText3)

JavaScript realizes click-through image switching effect: professional tutorial JavaScript realizes click-through image switching effect: professional tutorial Sep 18, 2025 pm 01:03 PM

This article will introduce how to use JavaScript to achieve the effect of clicking on images. The core idea is to use HTML5's data-* attribute to store the alternate image path, and listen to click events through JavaScript, dynamically switch the src attributes, thereby realizing image switching. This article will provide detailed code examples and explanations to help you understand and master this commonly used interactive effect.

How to get the user's location with the Geolocation API in JavaScript? How to get the user's location with the Geolocation API in JavaScript? Sep 21, 2025 am 06:19 AM

First, check whether the browser supports GeolocationAPI. If supported, call getCurrentPosition() to get the user's current location coordinates, and obtain the latitude and longitude values ​​through successful callbacks. At the same time, provide error callback handling exceptions such as denial permission, unavailability of location or timeout. You can also pass in configuration options to enable high precision, set the timeout time and cache validity period. The entire process requires user authorization and corresponding error handling.

How to create a multi-line string in JavaScript? How to create a multi-line string in JavaScript? Sep 20, 2025 am 06:11 AM

TheBestAtOrreatEamulti-LinestringinjavascriptSisingStisingTemplatalalswithbacktTicks, whichpreserveTicks, WhichpreserveReKeAndEExactlyAswritten.

Number formatting in JavaScript: Use toFixed() method to retain fixed decimal places Number formatting in JavaScript: Use toFixed() method to retain fixed decimal places Sep 16, 2025 am 11:57 AM

This tutorial explains in detail how to format numbers into strings with fixed two decimals in JavaScript, even integers can be displayed in the form of "#.00". We will focus on the use of the Number.prototype.toFixed() method, including its syntax, functionality, sample code, and key points to be noted, such as its return type always being a string.

The Nuxt 3 Composition API Explained The Nuxt 3 Composition API Explained Sep 20, 2025 am 03:00 AM

Nuxt3's Composition API core usage includes: 1. definePageMeta is used to define page meta information, such as title, layout and middleware, which need to be called directly in it and cannot be placed in conditional statements; 2. useHead is used to manage page header tags, supports static and responsive updates, and needs to cooperate with definePageMeta to achieve SEO optimization; 3. useAsyncData is used to securely obtain asynchronous data, automatically handle loading and error status, and supports server and client data acquisition control; 4. useFetch is an encapsulation of useAsyncData and $fetch, which automatically infers the request key to avoid duplicate requests

How to create a repeating interval with setInterval in JavaScript How to create a repeating interval with setInterval in JavaScript Sep 21, 2025 am 05:31 AM

To create a repetition interval in JavaScript, you need to use the setInterval() function, which will repeatedly execute functions or code blocks at specified milliseconds intervals. For example, setInterval(()=>{console.log("Execute every 2 seconds");},2000) will output a message every 2 seconds until it is cleared by clearInterval(intervalId). It can be used in actual applications to update clocks, poll servers, etc., but pay attention to the minimum delay limit and the impact of function execution time, and clear the interval in time when no longer needed to avoid memory leakage. Especially before component uninstallation or page closing, ensure that

Common pitfalls and solutions for DOM element access in JavaScript Common pitfalls and solutions for DOM element access in JavaScript Sep 15, 2025 pm 01:24 PM

This article aims to solve the problem of returning null when obtaining DOM elements through document.getElementById() in JavaScript. The core is to understand the script execution timing and DOM parsing status. By correctly placing the tag or utilizing the DOMContentLoaded event, you can ensure that the element is attempted again when it is available, effectively avoiding such errors.

How to copy text to the clipboard in JavaScript? How to copy text to the clipboard in JavaScript? Sep 18, 2025 am 03:50 AM

Use the writeText method of ClipboardAPI to copy text to the clipboard, it needs to be called in security context and user interaction, supports modern browsers, and the old version can be downgraded with execCommand.

See all articles