Skip to content Skip to sidebar Skip to footer

Refresh Div, But Only If There Is New Content From Php File

Background Info I'm fiddling around with some PHP and AJAX at the moment, to try and get the code working for an auto refreshing div (every 10 seconds), that contains comments. Her

Solution 1:

I've faced similar problem not too long ago, i assume that you using mysql or something for your comments storage serverside ?

I solved my problem by first adding timestamp integer column to my mysql table, then when i added a new row, i'd just simply use time() to save the current time.

mysql row insert example:

$query = "INSERT INTO comments (name, text, timestamp) VALUES ('". $name ."', '". $text ."',". time() .");";

step two would be to json_encode the data you sending from serverside:

$output = array();

if ($html && $html !== '') {   // do we have any script output ?$output['payload'] = $html;  // your current script output would go in this variable
}
$output['time'] = time();      // so we know when did we last check for payload update$json = json_encode($output, ((int)JSON_NUMERIC_CHECK)); // jsonify the arrayecho$json;                    // send it to the client

So, now instead of pure html, your serverside script returns something like this:

{
  "payload":"<div class=\"name\">Derpin<\/div><div class=\"msg\">Foo Bar!<\/div>",
  "time":1354167493
}

You can grab the data in javascript simply enough:

<scripttype="text/javascript">// <![CDATA[var lastcheck;
var content_main = $('#content_main');

pollTimer = setInterval(function() {
  updateJson();
}, 10000);

functionupdateJson() {
  var request = '/feed_main.php?timestamp='+ (lastcheck ? lastcheck : 0);

  $.ajax({
    url: request,
    dataType: 'json',
    async: false,
    cache: false,
    success: function(result) {
      if (result.payload) {        // new data
        lastcheck = result.time;   // update stored timestamp
        content_main.html(result.payload + content_main.html()); // update html element
      } else {                     // no new data, update only timestamp
        lastcheck = result.time;
      }
    }
  });
}

// ]]> </script>

that pretty much takes care of communication between server and client, now you just query your database something like this:

$timestamp = 0;
$where = '';

if (isset($_GET['timestamp'])) {
  $timestamp = your_arg_sanitizer($_GET['timestamp']);
}

if ($timestamp) {
  $where = ' WHERE timestamp >= '.$timestamp;
}

$query = 'SELECT * FROM comments'. $where .' ORDER BY timestamp DESC;';

The timestamps get passed back and forth, client always sending the timestamp returned by the server in previous query.

Your server only sends comments that were submitted since you checked last time, and you can prepend them to the end of the html like i did. (warning: i have not added any kind of sanity control to that, your comments could get extremely long)

Since you poll for new data every 10 seconds you might want to consider sending pure data across the ajax call to save substantial chunk bandwidth (json string with just timestamp in it, is only around 20 bytes).

You can then use javascript to generate the html, it also has the advantage of offloading lot of the work from your server to the client :). You will also get much finer control over how many comments you want to display at once.


I've made some fairly large assumptions, you will have to modify the code to suit your needs. If you use my code, and your cat|computer|house happens to explode, you get to keep all the pieces :)

Solution 2:

How about this:

<scripttype="text/javascript">// <![CDATA[
    $(function () {

        functionreload (elem, interval) {
            var $elem = $(elem);
            // grab the original htmlvar $original = $elem.html();
            $.ajax({
                cache : false,
                url : '/feed_main.php',
                type : 'get',
                success : function (data) {
                    // compare the result to the originalif ($original == data) {
                        // just start the timer if the data is the samesetTimeout(function () {
                            reload(elem, interval)
                        }, interval);
                        return;
                    }
                    // or update the html with new data
                    $elem.html(data);
                    // and start the timersetTimeout(function () {
                        reload(elem, interval)
                    }, interval);
                }
            });
        }

        // call it the first timereload('#content_main', 10000);
    });
    // ]]></script>

This is just an idea to get you going it doesn't deal with errors or timeouts.

Solution 3:

Best And Easy Code

setInterval(function()
    { 
        $.ajax({
          type:"post",
          url:"uourpage.php",
          datatype:"html",
          success:function(data)
          {
            $("#div").html(data);
          }
        });
    }, 5000);//time in milliseconds 

Post a Comment for "Refresh Div, But Only If There Is New Content From Php File"