Skip to main content

How to detect page scroll to bottom of a React component

Depending on your UI framework, some of them don't really support scroll aware components. If you had to work on one of them, then this will be great for you.

I had to work with one of the old UI frameworks with ReactJs. It didn't support any scroll event awareness by default. So, I had to write some custom logic to do that.

Following is a sample component with scroll event awareness to detect the bottom.


class MyComponent extends React.Component {

   constructor(props) {
     super(props);
     
     //atBottom state is kept to smooth things out, 
     // to avoid again and again detecting the bottom event if we are at the bottom
     this.state = {atBottom: false};
     // This binding is necessary to make `this` work in the callback
     this.handleScroll = this.handleScroll.bind(this);
   }
 
   handleScroll(event) {
      console.log("scrolled");
      const element = document.getElementById('mylist');
      if (!this.state.atBottom && this.isBottom(element)) {
        this.setState({atBottom: true});
        alert("bottom reached");
      }
      if (!this.isBottom(element)) {
        this.setState({atBottom: false});
      }
   }
   
   componentDidMount() {
      document.addEventListener('scroll', this.handleScroll);
   }
   
   componentWillUnmount() {
      document.removeEventListener('scroll', this.handleScroll);
   }
   
   isBottom(element) {
      return element.getBoundingClientRect().bottom <= window.innerHeight;
   }
    
   
   render() {
      return (
         <div>
            <h1>My component</h1>
         </div>
      );
   }
 }
 
 ReactDOM.render(
   <MyComponent/>,
   document.getElementById('root')
 );
 


Here, I have used a custom event listener to identify the scroll event. I'm adding the listener to the document when the component is mounted. Also, it is mandatory to keep in mind to remove the listener when the component unmounted. Otherwise, during a page change, or a tab change the same event will be captured during other parts of the application as well.

Also, I've used a state to make sure the bottom detection is done smoothly. Otherwise, it will keep detecting the bottom even you are still at the bottom in the previous scroll.

If you see, in the constructor, I have bounded the "this" object into the handler method. If you don't do that, this at the handler method will refer to the document.

You can try this code in action with the following codepen URL.

https://codepen.io/thilinaj/pen/qBbmogo






Comments

Popular posts from this blog

Install Docker on Windows 11 with WSL Ubuntu 22.04

This is to install Docker within Ubuntu WSL without using the Windows Docker application. Follow the below steps. Install Ubuntu 22.04 WSL 1. Enable Windows Subsystem for Linux and Virtual Machine platform Go to Control Panel -> Programs -> Programs and Features -> Turn Windows features on or off 2. Switch to WSL 2 Open Powershell and type in the below command. wsl --set-default-version 2 If you don't have WSL 2, download the latest WSL 2 package and install it.  3. Install Ubuntu Open Microsoft Store and search for Ubuntu. Select the version you intend to install. I'd use the latest LTS version Ubuntu 22.04. Click on the Get button. It will take a couple of minutes to download and install. 4. Open up the installed Ubuntu version that was installed. If you get an error like the below image, make sure to install the WSL2 Kernel update .  If it's an older Ubuntu version the error message would be something like the image below. Error: WSL 2 requires an update to its

How to fix SSLHandshakeException PKIX path building failed in Java

TL ; DR 1. Extract the public certificate of the website/API that you are trying to connect from your Java application. Steps are mentioned in this post 2. Use the Java keytool to install the extracted certificate into the "cacerts" file (Trust store) keytool -import -trustcacerts -alias <domain name> -file <public certificate>.cert -keystore /path_to_java_home/jre/lib/security/cacerts -storepass changeit 3. Restart your Java application Exception A typical exception stack trace would look like below. javax.net.ssl. SSLHandshakeException : sun.security.validator.ValidatorException: PKIX path building failed : sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target at sun.security.ssl.Alerts.getSSLException(Alerts.java:192) at sun.security.ssl.SSLSocketImpl.fatal(SSLSocketImpl.java:1959) at sun.security.ssl.Handshaker.fatalSE(Handshaker.java:302) at sun.security.ssl.Handshake

Automatically open Chrome developer tools in a new tab

Sometimes we need to check the console or the network transactions of a link that opens up in a new tab. By default, the Chrome developer tools are not opening in a new tab. So, by the time when we hit F12 and open the dev tools, part of the information we needed could be already gone.  There's a setting in dev tools where you can keep the dev tools open automatically in a new tab. To enable that, hit F12 and open up the dev tools. Click on the settings icon in the top right corner. In the Preferences section, scroll down to the bottom. You'll be able to find the option to Auto-open DevTools for popups. Select the checkbox and we're good to go!