Skip to content

React DOM events on components

I wanted to show or hide a little panel based on the mouse hover status.

When I hovered a link, the panel would show up.

Then I could enter this panel with the mouse, and when I moved the mouse away, the panel would hide.

Like the Twitter profile that shows when you move the mouse upon the name of a person:

on the <a> element that triggered the panel to show up, I added the event onMouseEnter:

<a
  onMouseEnter={() => {
    setShowCard(true)
  }}
>flavio</a>

so the panel would show when I hovered it with the mouse, because it was shown depending on the showCard state variable I had set before:

const [showCard, setShowCard] = useState(false)

Then I had the ProfileCard component but I couldn’t just do:

<ProfileCard
onMouseEnter={() => {
  setShowCard(true)
}}
onMouseLeave={() => {
  setShowCard(false)
}}
/>

because it didn’t work. ProfileCard is not a DOM element, so it didn’t get the events fired to respond to.

What I had to do was to pass onMouseEnter and onMouseLeave as props to the ProfileCard component, then identify the correct DOM element inside it that could receive those events, and attach the event handler there. In this case, I used the container div:

const ProfileCard = ({
  onMouseEnter,
  onMouseLeave
}) => (
  <div
    onMouseEnter={onMouseEnter}
    onMouseLeave={onMouseLeave}>
      ...

Now leaving the panel would hide it.


→ Get my React Beginner's Handbook

download all my books for free

  • javascript handbook
  • typescript handbook
  • css handbook
  • node.js handbook
  • astro handbook
  • html handbook
  • next.js pages router handbook
  • alpine.js handbook
  • htmx handbook
  • react handbook
  • sql handbook
  • git cheat sheet
  • laravel handbook
  • express handbook
  • swift handbook
  • go handbook
  • php handbook
  • python handbook
  • cli handbook
  • c handbook

subscribe to my newsletter to get them

Terms: by subscribing to the newsletter you agree the following terms and conditions and privacy policy. The aim of the newsletter is to keep you up to date about new tutorials, new book releases or courses organized by Flavio. If you wish to unsubscribe from the newsletter, you can click the unsubscribe link that's present at the bottom of each email, anytime. I will not communicate/spread/publish or otherwise give away your address. Your email address is the only personal information collected, and it's only collected for the primary purpose of keeping you informed through the newsletter. It's stored in a secure server based in the EU. You can contact Flavio by emailing [email protected]. These terms and conditions are governed by the laws in force in Italy and you unconditionally submit to the jurisdiction of the courts of Italy.

Related posts about react: