How to use useEffect callback with event callbacks
I was running some code like this:
useEffect(() => {
if (!socket) return
socket.on('newuserconnected', (username) => {
console.log(connectedusers)
})
}, [socket])
to initialize a callback for an event newuserconnected
on a socket.io connection.
I assumed that after doing so, any time I called that event on the server, the client-side (React app) would print the current value at runtime of the variable connectedusers
(imagine I was updating it somewhere else in the app).
But no, the value of that variable was “stuck in time” at the moment I defined that event.
What I had to do to fix the problem was to add that variable value to the list of variables that the useEffect
call depends on:
useEffect(() => {
//...
}, [socket, connectedusers])
→ I wrote 17 books to help you become a better developer:
- C Handbook
- Command Line Handbook
- CSS Handbook
- Express Handbook
- Git Cheat Sheet
- Go Handbook
- HTML Handbook
- JS Handbook
- Laravel Handbook
- Next.js Handbook
- Node.js Handbook
- PHP Handbook
- Python Handbook
- React Handbook
- SQL Handbook
- Svelte Handbook
- Swift Handbook
Also, JOIN MY CODING BOOTCAMP, an amazing cohort course that will be a huge step up in your coding career - covering React, Next.js - next edition February 2025