Skip to content

How to use useEffect callback with event callbacks

FULL-STACK WEB DEVELOPMENT BOOTCAMP

2024 COHORT SIGNUPS END TOMORROW

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])
β†’ Get my React Beginner's Handbook
β†’ Read my full React Tutorial
  • Learn modern web development in my BOOTCAMP (SIGNUP END TOMORROW FEB 20, 2024)
  • THE VALLEY OF CODE (+ PRO), your web development manual
  • I wrote 15+ coding BOOKS, all available in THE VALLEY OF CODE PRO
  • Indie solopreneur internet business masterclass SOLO LAB (summer 2024)