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

Java, how to create a list with a single element

 I wanted to create a Java List with a single element. Yet, I wanted to add more elements later. So, I was looking for a couple of ways to do this. So far there are multiple elegant ways to create a list with a single element with a one-liner. Not so much for a modifiable list though. Here's what I gathered so far. Followings are a few ways of creating a list with strictly a single entry. Can't add more elements. 1. Collections.singletonList() This returns an immutable list that cannot be modified or add more elements. // An immutable list containing only the specified object. List<String> oneEntryList = Collections. singletonList ( "one" ) ; oneEntryList.add( "two" ) ; // throws UnsupportedOperationException 2.  Arrays.asList() This returns a fixed-size list consisting of the number of elements provided as arguments. The number of elements provided would be an array hence the size is fixed to the length of the array. // Returns a fixed-size list List...

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...

Ubuntu DNS issue fix DNS_PROBE_FINISHED_BAD_CONFIG

Issue  I've been playing with a VPN and somehow it messed up my DNS resolution configurations. Chrome gives  DNS_PROBE_FINISHED_BAD_CONFIG  error and can't ping google. So it seemed to be an issue with the DNS. Of course, restarting didn't fix it. I tried DNS lookup which gave me below. To make sure this is somehting to do with my DNS confgis, I ran the same by providing the google DNS servers.  It works, which means my default DNS is not working for some reason. To make sure this, ran the below command. systemd-resolve --status Output has an entry for DNS Servers, which was  ::1 Fix 1. Edit the file /etc/systemd/resolved.conf. sudo vi /etc/systemd/resolved.conf 2. Add new DNS entries. I added 2 google DNS and the cloudflare DNS sever. [Resolve] DNS=8.8.8.8 8.8.4.4 1.1.1.1 3. Restart the systemd-resolved and check the configuration is persisted in /run/systemd/resolve/resolv.conf file. sudo service systemd-resolved restart cat /run/systemd/resolve/resolv.co...