Dependencies

Loading "Dependencies"
πŸ‘¨β€πŸ’Ό Our users wanted to be able to control vanilla-tilt a bit. Some of them like the speed and glare to look different. So Kellie πŸ§β€β™‚οΈ added a form that will allow them to control those values. This is working great, but something we noticed is the tilt effect is getting reset whenever you click the count button!
πŸ¦‰ The reason this happens is because the ref callback is called every time the component is rendered (and the cleanup runs between renders). So we're re-initializing the tilt effect on every render.
πŸ‘¨β€πŸ’Ό This is inefficient and it's a jarring experience if the user clicks on the corner of the count button. We want the effect to only re-initialize when the options change.
The trick is we want the effect to re-initialize when the vanillaTiltOptions change, but nothing else. So we can use useEffect to do that:
useEffect(
	() => {
		// set up stuff
		return function cleanup() {
			// clean up stuff
		}
	},
	// depend on stuff:
	[],
)
πŸ¦‰ React needs to know when it needs to run your effect callback function again. We do this using the dependency array which is the second argument to useEffect. Whenever values in that array changes, React will call the returned cleanup function and then invoke the effect callback again.
By default, if you don't provide a second argument, useEffect runs after every render (similar to what we're currently experiencing with the ref callback). While this is probably the right default for correctness, it's far from optimal in most useEffect cases. If you're not careful, it's easy to end up with infinite loops (imagine if you're calling setState in the effect which triggers another render, which calls the effect, which calls setState and so on).
πŸ‘¨β€πŸ’Ό So what we need to do in this step is move our ref callback stuff to useEffect, create a useRef so we can access the DOM node in the useEffect callback, and let React know that our effect callback depends on the vanillaTiltOptions the user is providing. Let's do that by passing the vanillaTiltOptions in the dependency array.
You'll notice an issue when you've finished this step. If you click the button to increment the count, the tilt effect is still reset! We'll fix this in the next step.
Login to get access to the exclusive discord channel.
  • 🎣Hooks
    rules of hooks violation
    seven πŸš€:
    Hi, we clearly violate the rules of hooks, is it allowecd with the use hook? ``` function ShipDetai...
    • βœ…1
    8 Β· 4 days ago
  • 🎣Hooks
    πŸ”€Suspense
    Clarification on how to trigger a suspense
    seven πŸš€:
    Hello, in lesson about useTransition Kent said that "anytime you have a state update thats going to ...
    3 Β· 3 days ago
  • 🎣Hooks
    Issue with video captions
    Hawk πŸš€:
    Not a big issue but on the intro video for React hooks, the video captions block most of the video f...
    • βœ…1
    1 Β· 25 days ago
  • General
    AI Assistant?
    John πŸš€:
    Kent has mentioned an AI assistant that he's using in VSCode. Is there any detail on what that is an...
    • βœ…2
    2 Β· a month ago
  • General
    Script to save playground folder
    larissapissurno πŸš€:
    Hi all, I personally like to take notes on the playground files, so in order to not lose this notes ...
    • βœ…1
    2 Β· a month ago
  • General
    Runninng Learning app on iPad?
    marcus_polonus πŸš€:
    Hi all, Did anyone managed to setup learning app on iPad? I tried to use codesandbox, but when I am...
    • βœ…1
    1 Β· a month ago
  • General
    Welcome to EpicReact.dev! Say Hello πŸ‘‹
    Kent C. Dodds β—† πŸš€πŸ†πŸŒŒ:
    Welcome to the first of many posts in the EpicReact.dev channel! Take a moment to introduce yourself...
    • πŸš€5
    46 Β· 18 days ago
  • General
    βš›οΈFundamentals
    Error boundary good practice
    Lloren πŸš€:
    I have always wondered if the error boundary is there a limit of error boundary that you can impleme...
    • βœ…1
    1 Β· a month ago
  • General
    Launch editor error: Could not open 'index.html' from:'playground' in the editor.
    Japhet πŸš€ πŸ†:
    I'm encountering an issue when trying to open a link from the file list. The error message I receive...
    • βœ…1
    15 Β· a month ago
  • General
    Received this error when running the setup script for React Fundamentals
    ChrisP πŸš€:
    Hey guys, I am completely blocked at the moment. When I clone and run the setup for react fundamenta...
    • βœ…1
    2 Β· a month ago
  • General
    Unexpected server error (workshop-app does not load onboarding step)
    Matias 🌌 πŸš€:
    Hey! πŸ‘‹ I installed the free workshop "Build React Hooks" last week with no issues. Yesterday, whe...
    • βœ…1
    3 Β· a month ago
  • General
    Eye opening moment in 05/06 (β€žsatisfiesβ€œ operator of typescript)
    Chrigi πŸš€:
    Up until today I was not aware that having the type annotation on a variable is actually a type-cast...
    • πŸ™Œ2
    • βœ…1
    2 Β· a month ago
  • General
    Launch editor error: spawn code ENOENT
    Andrew Elans 🌌 πŸš€:
    Clicking index.html gives this error in VS Code. Both from Chrome and Safari. Anyone?
    • βœ…2
    4 Β· 2 months ago
  • General
    Failed to fetch dynamically imported module...
    FacuPerezM:
    I am getting this error out of nowhere, in the 'test' tab inside the Workshop app. ``` Failed to f...
    • βœ…1
    3 Β· a month ago
  • General
    Epicshop not saving the video resolution
    Toni πŸš€ 🌌:
    Playback speed and caption settings are saved, but the video resolution always defaults to auto. Is ...
    • βœ…1
    7 Β· 2 months ago
  • General
    Clicking an exercise file launch VIM instead of VS Code
    DBattou πŸš€:
    I started going through the workshops, everything is setup and working fine except for opening a fil...
    • βœ…1
    2 Β· 2 months ago