Skip to content

Commit

Permalink
Emphasize the second problem paragraph with chain of effects example …
Browse files Browse the repository at this point in the history
…(#7108)

* Emphasize the second problem acapit with chain of effects example

* Replace 'One' with 'First' to keep problems counting consistent
  • Loading branch information
BartoszKlonowski authored Aug 25, 2024
1 parent b5f28b4 commit 7d50c3f
Showing 1 changed file with 2 additions and 2 deletions.
4 changes: 2 additions & 2 deletions src/content/learn/you-might-not-need-an-effect.md
Original file line number Diff line number Diff line change
Expand Up @@ -408,9 +408,9 @@ function Game() {
There are two problems with this code.
One problem is that it is very inefficient: the component (and its children) have to re-render between each `set` call in the chain. In the example above, in the worst case (`setCard` β†’ render β†’ `setGoldCardCount` β†’ render β†’ `setRound` β†’ render β†’ `setIsGameOver` β†’ render) there are three unnecessary re-renders of the tree below.
First problem is that it is very inefficient: the component (and its children) have to re-render between each `set` call in the chain. In the example above, in the worst case (`setCard` β†’ render β†’ `setGoldCardCount` β†’ render β†’ `setRound` β†’ render β†’ `setIsGameOver` β†’ render) there are three unnecessary re-renders of the tree below.
Even if it weren't slow, as your code evolves, you will run into cases where the "chain" you wrote doesn't fit the new requirements. Imagine you are adding a way to step through the history of the game moves. You'd do it by updating each state variable to a value from the past. However, setting the `card` state to a value from the past would trigger the Effect chain again and change the data you're showing. Such code is often rigid and fragile.
The second problem is that even if it weren't slow, as your code evolves, you will run into cases where the "chain" you wrote doesn't fit the new requirements. Imagine you are adding a way to step through the history of the game moves. You'd do it by updating each state variable to a value from the past. However, setting the `card` state to a value from the past would trigger the Effect chain again and change the data you're showing. Such code is often rigid and fragile.
In this case, it's better to calculate what you can during rendering, and adjust the state in the event handler:
Expand Down

0 comments on commit 7d50c3f

Please sign in to comment.