Generally, we saw in many websites with pagination at the bottom. The concept of pagination comes with an idea that if you have a lot of posts in your website then instead of showing all the posts in one page, you can show that in that page but with different sections. These sections are called pagination parts. For more information about pagination, visit our this post about how to implement pagination in wordpress. In the current post, we will discus about how to implement infinite scroll to load the posts using ajax.
As we know that ajax is a very powerful tool that provides a feature that we can do any task without even refreshing the page. Currently, almost every website uses this feature to load data or even images. We will also use this feature to implement our task.
To do so, follow these simple steps:
Step 1:
First of all, we will call the ajax inside the header section of our website because the header section is always called before any other section. SO open your header.php file and copy-paste the following code into that file.
<?php if (!is_single() || !is_page()): ?>
<script type="text/javascript">
    jQuery(document).ready(function($) {
        var count = 2;
        var total = <?php echo $wp_query->max_num_pages; ?>;
        $(window).scroll(function(){
                if  ($(window).scrollTop() == $(document).height() ){
                   if (count > total){
                             return false;
                   }else{
                           loadArticle(count);
                   }
                   count++;
                }
        });
        function loadArticle(pageNumber){    
                $('a#inifiniteLoader').show('fast');
                $.ajax({
                    url: "<?php bloginfo('wpurl') ?>/wp-admin/admin-ajax.php",
                    type:'POST',
                    data: "action=infinite_scroll&page_no="+ pageNumber + '&loop_file=loop', 
                    success: function(html){
                        $('a#inifiniteLoader').hide('1000');
                        $("#content").append(html);    // This will be the div where our content will be loaded
                    }
                });
            return false;
        }
    });
</script>
Step 2:
Now your header part is ready with the ajax functionality. Now you have to take care offunction.php file. So open your function.php and copy-paste the following code into that file.
<?php
add_action('wp_ajax_infinite_scroll', 'wp_infinitepaginate');           // for logged in user
add_action('wp_ajax_nopriv_infinite_scroll', 'wp_infinitepaginate');    // if user not logged in
function wp_infinitepaginate(){
    $loopFile        = $_POST['loop_file'];
    $paged           = $_POST['page_no'];
    $posts_per_page  = get_option('posts_per_page');
    query_posts(array('paged' => $paged ));
    get_template_part( $loopFile );
    exit;
}
function my_scripts_method() {
    wp_deregister_script( 'jquery' );
    wp_register_script( 'jquery', 'http://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js’');
    wp_enqueue_script( 'jquery' );
}    
add_action('wp_enqueue_scripts', 'my_scripts_method');
Now you are almost there with complete ajax. In the last, you have to be sure that yourindex.php file should have a div with id=’content’ as given in the following code:
<div id="content" role="main">
    <!-- code for your posts. -->
 </div>
Now your website is ready for loading the posts on infinite scroll with ajax.