data:image/s3,"s3://crabby-images/710fb/710fb16b42eed188d667ff18a9f2af2343c8eb06" alt="React course"
Now `squares` is unchanged, but `nextSquares` first element is 'X' rather than `null`
data:image/s3,"s3://crabby-images/28509/285092ddf98c434891c125e187e196664157863e" alt="react course react course"
In the end the user sees that the upper left square has changed from empty to having a X after clicking it. This causes the value prop of the Square component with index 0 to change from null to X.
data:image/s3,"s3://crabby-images/8ab33/8ab3373277661da0c57b39ebb0c5475972dd6e87" alt="react course react course"
Keeping the state of all squares in the Board component will allow it to determine the winner in the future. When the Board’s state changes, both the Board component and every child Square re-renders automatically.
data:image/s3,"s3://crabby-images/7e627/7e627aacaeef1c5fdbcad461e5ffcbbc0a2fdf87" alt="react course react course"
When clicking on a Square, the child Square component now asks the parent Board component to update the state of the board. Now that your state handling is in the Board component, the parent Board component passes props to the child Square components so that they can be displayed correctly.
data:image/s3,"s3://crabby-images/710fb/710fb16b42eed188d667ff18a9f2af2343c8eb06" alt="React course"