To implement scrolling to a specific content or element on click in a React application, you can follow these steps:
- Identify the element you want to scroll to by giving it an
id
. - Implement a function that handles the scrolling behavior.
- 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 theid
of the element to scroll to, finds the corresponding element usingdocument.getElementById
, and then callsscrollIntoView
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:
- Prevent `#` from being appended to the url on click of an anchor tag
- 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.