Mehrere DIV Container mit AJAX aktualisieren

Diese Seite verwendet Cookies. Durch die Nutzung unserer Seite erklären Sie sich damit einverstanden, dass wir Cookies setzen. Weitere Informationen

  • Hier erfahrt ihr wie man mit AJAX mehrere DIV Container mit einem Request aktualisiert.
    == Einleitung ==
    Das folgende Script könnt ihr einerseits dazu verwenden mehrere Divs mit einem einzigen AJAX Request zu aktualisieren. Alle Div container können unabhängig aktualisiert werden.
    Außerdem ist das Script in der Lage die Daten ständig aktuell zu halten indem es in einem bestimmten Intervall die Daten aktualisiert.

    == Benutzung ==
    Die Nutzung ist einfach. Unten im Downloadbereich findet ihr zum einen die Scripte die ihr einbinden müsst.
    Ansonsten definiert ihr euch ein Updater wie folgt:

    Quellcode

    1. <script type="text/javascript">
    2. var up = new UpdateManyDivs('callback.php', 750);
    3. </script>


    == Parameter ==
    callback.php ist die Datei welche die Inhalte zur Verfügung stellt. 750 ist das Zeitintervall in Millisekunden zu dem die Updates geladen werden sollen.

    == Updatebereiche definieren ==
    Welche Container aktualisiert werden sollen macht ihr anhand der ElementID fest. Die ID des Containers und der Parameter beim update.push müssen übereinstimmen.
    Eine ID muss natürlich eindeutig sein.

    Quellcode

    1. <div id="update1">Ich werde aktualisiert #1</div>
    2. <script type="text/javascript">up.push('update1');</script>


    == Updates liefern (callback.php) ==
    In der Demo Applikation sieht die callback php wie folgt aus:

    Quellcode

    1. $data = array();
    2. foreach(array_keys($_GET) as $identfier) {
    3. $data[$identfier] = getRandomText($identfier);
    4. }
    5. echo json_encode($data);


    statt der getRandomText müsst ihr nur eure sinnvolle Datenbankabfrage einbauen.
    === Beispiel: MySQL ===

    Quellcode

    1. function getTextMYSQL($identfier) {
    2. $sql = "SELECT text FROM tabelle WHERE id = $identifier";
    3. $res = mysql_query($sql);
    4. $row = mysql_fetch_array($res);
    5. return $row['text'];
    6. }


    === Beispiel: PDO ===

    Quellcode

    1. function getTextPDO($identfier) {
    2. $sql = "SELECT text FROM tabelle WHERE id = :identifier";
    3. $stmt = MyDB::getInstance()->prepare($sql);
    4. $stmt->execute(array(
    5. ':identifier' => $identfier
    6. ));
    7. $row = $stmt->fetch();
    8. return $row['text'];
    9. }


    == Code ==
    Download

    Quellcode

    1. /**
    2. * xxx [..] by http://www.easy-coding.de
    3. *
    4. * @param url
    5. * @param poll
    6. */
    7. function UpdateManyDivs(url, poll) {
    8. this.url = url;
    9. this.poll = poll ? poll : 750;
    10. this.list = [];
    11. this.timer = null;
    12. /**
    13. * adds elem
    14. * @param id string as id
    15. */
    16. this.push = function(id) {
    17. this.list.push(id);
    18. };
    19. /**
    20. * sends single request
    21. * @param loop boolean
    22. */
    23. this.fire = function(loop) {
    24. ajaxPost(this.url + '?' +this.list.join('&'), 'seed='+ new Date().getTime(), function(up) {
    25. return function() {
    26. if (this.readyState == 4 && this.status == 200) {
    27. if(loop) {
    28. // start timer
    29. up.start();
    30. }
    31. var data = eval('(' + this.responseText + ')');
    32. for(var key in data) {
    33. document.getElementById(key).innerHTML = data[key];
    34. }
    35. }
    36. };
    37. }(this));
    38. };
    39. /**
    40. * stops auto updater
    41. */
    42. this.stop = function() {
    43. window.clearTimeout(this.timer);
    44. };
    45. /**
    46. * starts auto updater
    47. */
    48. this.start = function() {
    49. this.timer = window.setTimeout(function(up) {
    50. return function() {
    51. up.fire(true);
    52. };
    53. }(this), this.poll);
    54. };
    55. }
    Alles anzeigen


    == Steuerung ==
    Ihr steuert das Verhalten mit 3 Funktionen. Zum einen könnt ihr das Update manuell erzwingen. Ihr könnt das Update aber auch über einen automatischen Updater realisieren.

    Quellcode

    1. <a href="#" onclick="up.fire()">force single update</a>
    2. <a href="#" onclick="up.start()">start autoupdate</a>
    3. <a href="#" onclick="up.stop()">disable autoupdate</a>


    Wenn ihr den automatischen Updater immer aktivieren wollt, dann startet ihr doch einfach beim Laden des Dokuments:

    Quellcode

    1. <body onload="up.start()">


    == Demo ==
    Eine Live Demo mit allen möglichen Formularelementen findet ihr unter demo.easy-coding.de/ajax/mehre…tainer-ajax-aktualisieren. Des weiteren wird der kompletten Code hier als ZIP Archiv zur Verfügung gestellt: download.zip.
    Bilder
    • autoupdate.png

      6,35 kB, 722×278, 1.419 mal angesehen

    17.700 mal gelesen

Kommentare 4

  • Torben Brodt -

    Naja, mit while geht das so:
    [syntax="php"]function getTextMYSQL($identfier) {
    $sql = "SELECT * FROM mitglieder ORDER BY userid DESC LIMIT 0,2";
    $res = mysql_query($sql);
    $text = "";
    while($row = mysql_fetch_array($res)) {
    $text .= '<a href="'.$row['userid'].'">'.$row['username'].'</a>';
    }
    return $text;
    }[/syntax]

  • truemaster -

    Wie kriege ich denn jetzt eine DB Abfrage in der callback.php hin mit ner while abfrage... das klappt bei mir nicht..

    Also will anstatt

    [code] $sql = "SELECT * FROM mitglieder ORDER BY RAND() LIMIT 0,2";
    $res = mysql_query($sql);
    $row = mysql_fetch_array($res);
    return 'Username:'.$row['username'];[/code]

    mit while arbeiten also die letzten 10 user ausgeben

    das klappt aber leider nicht

    mfg

  • Torben Brodt -

    Ich habe Beispiele für MySQL ergänzt.

  • Catarrer -

    top erklährt ;)
    nur eins noch: wie sieht die callback aus, wenn ichs aus der datenbank hole?


    alla "SELECT * FROM ... WHERE name = update1"; oder wie?

    da steig ich noch ned ganz durch

    gruß adi