Loading...

How to smoothly scroll to a specific content or element in React?

question react front-end
Ram Patra Published on February 19, 2024

To implement scrolling to a specific content or element on click in a React application, you can follow these steps:

  1. Identify the element you want to scroll to by giving it an id.
  2. Implement a function that handles the scrolling behavior.
  3. Attach an event listener, such as an onClick handler, to the element that triggers the scrolling function.

Here’s how you can do it in a React component:

import React from 'react';

function scrollToElement(id) {
  const element = document.getElementById(id);
  if (element) {
    element.scrollIntoView({ behavior: 'smooth' });
  }
}

function MyComponent() {
  return (
    <div>
      <button onClick={() => scrollToElement('myContent')}>
        Scroll to Content
      </button>
      <div style= />
      <div id="myContent">
        Content to scroll to
      </div>
    </div>
  );
}

export default MyComponent;

In this example:

  • We have a button that triggers the scrolling behavior when clicked.
  • The scrollToElement function takes the id of the element to scroll to, finds the corresponding element using document.getElementById, and then calls scrollIntoView on it with { behavior: 'smooth' }.
  • Below the button, there’s a placeholder <div> with some height to create space for scrolling.
  • Following that, there’s the content we want to scroll to, which has the id of 'myContent'.

This example demonstrates scrolling within the same page. If you’re navigating to a different page within a Next.js application and want to scroll to a specific content element on that page, you would typically pass some sort of identifier or reference to the destination page and then trigger the scrolling behavior once the new page is mounted.

Now, to make the above method a bit more polished, we can do two things:

  1. Prevent `#` from being appended to the url on click of an anchor tag
  2. Add a `padding` option which will determine the offset from the top of the element to stop scrolling before
export function scrollToElement(event: React.MouseEvent<HTMLElement, MouseEvent>, id: string, padding: number = 0) {
    event.preventDefault();
    
    const element = document.getElementById(id);
    if (element) {
        const targetPosition = element.getBoundingClientRect().top + window.scrollY - padding;
        window.scrollTo({ top: targetPosition, behavior: "smooth" });
    }
}

Now, you can call this method from an anchor tag like this:

<a href="#" onClick={(e) => {scrollToElement(e, 'myContent', 80)}}>Click</a>

Although the above solution works perfectly fine, I personally prefer this simpler solution that involves only one line of CSS.

Presentify

Take your presentation to the next level.

FaceScreen

Put your face and name on your screen.

KeyScreen

Show keypresses on your screen.

ToDoBar

Your to-dos on your menu bar.

SimpleFill

Fill forms using your right-click menu.

IconSim

Preview your Mac app icons.

Ram Patra Published on February 19, 2024
Image placeholder

Keep reading

If this article was helpful, others might be too

question nextjs react February 9, 2024 Main advantages of using the Link component in Next.js over Anchors and Buttons

The main advantage of using the Link component in Next.js for client-side navigation is its optimized prefetching behavior, which enhances the performance and user experience of your web application. Here’s a breakdown of the key advantages:

question nextjs react November 17, 2024 How to define metadata in a client component in Nextjs?

Nextjs does not allow defining the metadata object in client components. There are a couple of ways to resolve this problem. I will be talking about two of them here.

question react tailwindcss September 19, 2024 A simple React Tooltip component that uses TailwindCSS only (no libraries)

Here’s a React component that allows you to attach the tooltip to any element by passing it as a child. The component will render the tooltip and an arrow pointing downward.

Like my work?

Please, feel free to reach out. I would be more than happy to chat.