Facebook Style Load Data in Timeline with PHP MySQL Ajax With Source Code
The Facebook Style Load Data in Timeline with PHP MySQL Ajax was developed using PHP, Ajax and MySQL Database as Back-End, If you’ve ever used a social media website like Facebook, you’ll know that when the page loads in the browser, it first loads the content loading placeholder and then loads the content on the web page.
The Timeline feature of web development was used to present content on the web page. So, when the first page loads, the timeline skeleton loads first, with a loading placeholder, and then the actual page loads.
So, in this tutorial Auto Load More Data On Page Scroll In PHP, we’ll use PHP script to create a project content loading placeholder, and then use PHP script with Ajax, Mysql database, and jQuery to load data onto a web page.
When we scroll down a web page to see more information, it first loads a timeline content loading placeholder using CSS and jQuery, and then it sends a request using Ajax.
In this Timeline Script Like Facebook also includes a downloadable Facebook Style Load Data in Timeline With Source Code for free, just find the downloadable source code below and click to start downloading.
To start creating this Facebook Style Load Data in Timeline, makes sure that you have sublime or any platform of PHP and MySQL installed in your computer.
Facebook Style Load Data in Timeline: Steps on how to create the project
Time needed: 5 minutes
These are the steps on how to create Facebook Style Load Data in Timeline with PHP MySQL Ajax With Source Code
- Step 1: Create a project folder
First, create a project folder under “htdocs” folder and named it “Facebook Style Load Data in Timeline with PHP MySQL Ajax”.
- Step 2: Create a php file named “index.php”
Next, create a php file under “htdocs” folder and named it “index.php”.
- Step 3: Create a php file named “fetch.php”
Next, create a php file under “htdocs” folder and named it “fetch.php”.
- Step 4: Start Coding
last, you can now start coding, or you can copy the given source code below.
index.php
<!DOCTYPE html> <html> <head> <title>(IT SOURCE CODE)Facebook Style Load Data in Timeline with PHP Mysql Ajax</title> <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.js"></script> <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/4.0.0-beta.3/css/bootstrap.min.css" integrity="sha384-Zug+QiDoJOrZ5t4lssLdxGhVrurbmBWopoEl+M6BdEfwnCJZtKxi1KgxUyJq13dy" crossorigin="anonymous"> <link href="https://stackpath.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css" rel="stylesheet"> <link rel="stylesheet" href="https://unpkg.com/placeholder-loading/dist/css/placeholder-loading.min.css"> <style> .timeline { list-style: none; padding: 20px 0 20px; position: relative; } .timeline:before { top: 0; bottom: 0; position: absolute; content: " "; width: 3px; background-color: #eeeeee; left: 50%; margin-left: -1.5px; } .timeline > li { margin-bottom: 20px; position: relative; width: 50%; float: left; clear: left; } .timeline > li:before, .timeline > li:after { content: " "; display: table; } .timeline > li:after { clear: both; } .timeline > li:before, .timeline > li:after { content: " "; display: table; } .timeline > li:after { clear: both; } .timeline > li > .timeline-panel { width: 95%; float: left; border: 1px solid #d4d4d4; /*border-radius: 2px;*/ /*padding: 20px;*/ position: relative; -webkit-box-shadow: 0 1px 6px rgba(0, 0, 0, 0.175); box-shadow: 0 1px 6px rgba(0, 0, 0, 0.175); } .timeline > li > .timeline-panel:before { position: absolute; top: 26px; right: -15px; display: inline-block; border-top: 15px solid transparent; border-left: 15px solid #ccc; border-right: 0 solid #ccc; border-bottom: 15px solid transparent; content: " "; } .timeline > li > .timeline-panel:after { position: absolute; top: 27px; right: -14px; display: inline-block; border-top: 14px solid transparent; border-left: 14px solid #fff; border-right: 0 solid #fff; border-bottom: 14px solid transparent; content: " "; } .timeline > li > .timeline-badge { color: #fff; width: 24px; height: 24px; line-height: 50px; font-size: 1.4em; text-align: center; position: absolute; top: 16px; right: -12px; /*background-color: #999999;*/ z-index: 100; /* border-top-right-radius: 50%; border-top-left-radius: 50%; border-bottom-right-radius: 50%; border-bottom-left-radius: 50%; */ } .timeline > li.timeline-inverted > .timeline-panel { float: right; } .timeline > li.timeline-inverted > .timeline-panel:before { border-left-width: 0; border-right-width: 15px; left: -15px; right: auto; } .timeline > li.timeline-inverted > .timeline-panel:after { border-left-width: 0; border-right-width: 14px; left: -14px; right: auto; } .timeline-badge > a { color: #C5C7C5 !important; } .timeline-badge a:hover { color: #000 !important; } .timeline-title { margin-top: 0; color: inherit; } .timeline-body{ padding:15px; } .timeline-body > h1{ font-size:22px; } .timeline-body > h2{ font-size: 18px; font-weight: 700; margin:0; } .timeline-body > p, .timeline-body > ul { /*padding:20px; margin-bottom: 0;*/ padding:0; margin-bottom: 10px; } .timeline-body > p + p { margin-top: 5px; } .timeline-footer{ padding:20px; background-color:#f4f4f4; } .timeline-footer > a{ cursor: pointer; text-decoration: none; } .timeline > li.timeline-inverted{ float: right; clear: right; margin-top: 30px; margin-bottom: 30px; } .timeline > li:nth-child(2){ margin-top: 60px; } .timeline > li.timeline-inverted > .timeline-badge{ left: -12px; } @media (max-width: 767px) { ul.timeline:before { left: 40px; } ul.timeline > li { margin-bottom: 20px; position: relative; width:100%; float: left; clear: left; } ul.timeline > li > .timeline-panel { width: calc(100% - 90px); width: -moz-calc(100% - 90px); width: -webkit-calc(100% - 90px); } ul.timeline > li > .timeline-badge { left: 28px; margin-left: 0; top: 16px; } ul.timeline > li > .timeline-panel { float: right; } ul.timeline > li > .timeline-panel:before { border-left-width: 0; border-right-width: 15px; left: -15px; right: auto; } ul.timeline > li > .timeline-panel:after { border-left-width: 0; border-right-width: 14px; left: -14px; right: auto; } .timeline > li.timeline-inverted{ float: left; clear: left; margin-top: 30px; margin-bottom: 30px; } .timeline > li.timeline-inverted > .timeline-badge{ left: 28px; } } </style> </head> <body> <br /> <div class="container"> <h3 align="center">Facebook Style Load Data in Timeline with PHP Mysql Ajax</h3> <br /> <div class="card"> <div class="card-header">Dynamic Data</div> <div class="card-body"> <ul class="timeline"> <li class="clearfix" id="clearfix_id" style="float: none;"></li> </ul> <span id="no_more_data"></span> </div> </div> <br /> <br /> </div> </body> </html> <script> $(document).ready(function(){ var action = 'inactive'; function load_timeline_data(last_id = '') { $.ajax({ url:"fetch.php", method:"POST", data:{last_id:last_id}, dataType:'json', success:function(data) { setTimeout(function(){ $('.removeTimeline').remove(); $('#clearfix_id').remove(); $('.timeline').append(data.timeline_output); if(data.no_data_output != '') { $('#no_more_data').html(data.no_data_output); } action = 'inactive'; }, 1000); } }); } function make_skeleton() { var output = ''; $('#clearfix_id').remove(); for(var count = 0; count < 4; count++) { temporary_class = ''; if(count%2 != 0) { temporary_class = 'class="timeline-inverted removeTimeline"'; } else { temporary_class = 'class="removeTimeline"'; } output += '<li '+temporary_class+'>'; output += '<div class="timeline-badge primary"><a><i class="fa fa-dot-circle-o" aria-hidden="true"></i></a></div>'; output += '<div class="timeline-panel">'; output += '<div class="timeline-heading"></div>'; output += '<div class="timeline-body">'; output += '<div class="ph-item">'; output += '<div class="ph-col-4">'; output += '<div class="ph-picture"></div>'; output += '</div>'; output += '<div>'; output += '<div class="ph-row">'; output += '<div class="ph-col-12 big"></div>'; output += '<div class="ph-col-12"></div>'; output += '<div class="ph-col-12"></div>'; output += '<div class="ph-col-12"></div>'; output += '<div class="ph-col-12"></div>'; output += '</div></div></div>'; output += '</div>'; output += '</div></div></li>'; } output += '<li class="clearfix" id="clearfix_id" style="float: none;"></li>'; $('.timeline').append(output); } if(action == 'inactive') { make_skeleton(); setTimeout(function(){ load_timeline_data(); }, 3000); } $(window).scroll(function(){ var last_id = $('#clearfix_id').data('last_id'); if(last_id != '') { if($(window).scrollTop() + $(window).height() > $(".timeline").height() && action == 'inactive') { action = 'active'; make_skeleton(); setTimeout(function(){ load_timeline_data(last_id); }, 5000); } } }); }); </script>
fetch.php
<?php //fetch.php; $connect = new PDO("mysql:host=localhost; dbname=testing", "root", ""); if(isset($_POST["last_id"])) { //sleep(5); if($_POST["last_id"] != '') { $query = " SELECT * FROM tbl_post WHERE id < '".$_POST["last_id"]."' ORDER BY id DESC LIMIT 4 "; } else { $query = " SELECT * FROM tbl_post ORDER BY id DESC LIMIT 4 "; } $statement = $connect->prepare($query); $statement->execute(); $total_row = $statement->rowCount(); $output = ''; $not_found = ''; $last_id = 0; if($total_row > 0) { $result = $statement->fetchAll(); $count = 0; $class = ''; foreach($result as $row) { if($count%2 != 0) { $class = 'class="timeline-inverted"'; } else { $class = ''; } $output .= ' <li '.$class.'> <div class="timeline-badge primary"><a><i class="fa fa-dot-circle-o" aria-hidden="true"></i></a></div> <div class="timeline-panel"> <div class="timeline-heading"> <div class="col-md-12" style="padding:15px; background-color:#eee; border-bottom:#ddd 1px solid;"><h3>'.$row["post_title"].'</h3></div> </div> <div class="timeline-body"> <div class="row"> <div class="col-md-4"> <img src="images/'.$row["post_image"].'" class="img-thumbnail img-fluid" /> </div> <div class="col-md-8"> <p>'.$row["post_description"].'</p> </div> </div> </div> </div> </li>'; $last_id = $row["id"]; $count++; } } else { $not_found = ' <div align="center" class="alert alert-info">No more data found</div> '; } $output .= '<li class="clearfix" id="clearfix_id" data-last_id="'.$last_id.'" style="float: none;"></li>'; $test_output = array( 'timeline_output' => $output, 'no_data_output' => $not_found ); echo json_encode($test_output); } ?>
Output
Download Source Code below
Anyway, if you want to level up your programming knowledge, especially PHP, try this new article I’ve made for you Best PHP Projects With Source Code Free Download.
Summary
So, here we have merge the concept of Timeline, Load more data and content placeholder and make Project with PHP script, Mysql database, Ajax and jQuery. you can find complete source code.
Related Articles
- Website CMS in PHP Free Source Code
- Ticket Reservation System in PHP Free Download with QR Code
- E Commerce Project In PHP With Source Code
- Voting System source code using VB.Net and mySQL
Inquiries
If you have any questions or suggestions about Facebook Style Load Data in Timeline with PHP MySQL Ajax With Source Code, please feel free to leave a comment below.