IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

AJAX Discussion :

[AJAX] Rafraichir une partie de la page toutes les secondes


Sujet :

AJAX

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre habitué
    Inscrit en
    Juillet 2006
    Messages
    747
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 747
    Points : 185
    Points
    185
    Par défaut [AJAX] Rafraichir une partie de la page toutes les secondes
    Bonjour,

    Voici mon problème.
    Je dispose d'une page avec une table dans laquelle j'affiche un nombre aléatoire. Je voudrais faire en sorte que la cellule dans laquelle est affiché ce nombre se recharge toutes les secondes. Ne connaissant pas Ajax pour le moment, je ne sais pas du tout comment faire ça.

    Voici mon code pour l'instant:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    <html>
    <head>
    	<script language="javascript" type="text/javascript">
    		URL = "http://localhost/Test/test_Ajax/test.php";
    		function rafraichir() {
    				if (window.XMLHttpRequest) xhr = new XMLHttpRequest();
    				else if (window.ActiveXObject) xhr = new ActiveXObject('Microsoft.XMLHTTP');
    				else alert('JavaScript : votre navigateur ne supporte pas les objets XMLHttpRequest...');
    				xhr.open('GET',URL,true);
    				xhr.onreadystatechange = ajaxReponse;
    				xhr.send(null);
    		}
     
    		function ajaxReponse() {
    				if (xhr.readyState == 4) {
    						document.getElementById("test_refresh",true).innerHTML=xhr.responseText; 
    						var timer=setTimeout("rafraichir()",1000); 
    				}
    		}
    </script>
     
     
     
    </head>
    <body onLoad="javascript:rafraichir();">
    <table>
    	<tr>
    		<td id="test_refresh">
    			<?php 
                            $nb_min = 1;
                            $nb_max = 100;
                            $nombre = mt_rand($nb_min,$nb_max);
                            
                            echo $nombre;
                            ?>
    		</td>
    	</tr>
    </table>			
    </body>
    </html>
    Merci à toute personne qui pourra m'indiquer comment régler mon problème.

    A+

  2. #2
    Membre émérite
    Avatar de Nesmontou
    Homme Profil pro
    Architecte logiciel
    Inscrit en
    Septembre 2004
    Messages
    1 612
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 42
    Localisation : France, Nord (Nord Pas de Calais)

    Informations professionnelles :
    Activité : Architecte logiciel
    Secteur : Finance

    Informations forums :
    Inscription : Septembre 2004
    Messages : 1 612
    Points : 2 969
    Points
    2 969
    Par défaut
    Bonjour,

    Tu peux utiliser la fonction setInterval : http://javascript.developpez.com/faq...e=date#Horloge

    Bon développement
    Si vous ne pouvez expliquer un concept à un enfant de six ans, c'est que vous ne le comprenez pas complètement. Albert EINSTEIN

    F.A.Q. : Java, PHP, (X)HTML / CSS

    N'oubliez pas de cliquer sur le bouton Résolu en bas de page quand vous avez obtenu une solution à votre problème

  3. #3
    Membre habitué
    Inscrit en
    Juillet 2006
    Messages
    747
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 747
    Points : 185
    Points
    185
    Par défaut
    Yeeees, merci beaucoup Nesmontou !!

    Ça marche bien comme je veux !!!!
    (et dire que mon problème se trouvait seulement là !!! )

  4. #4
    Membre habitué
    Inscrit en
    Juillet 2006
    Messages
    747
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 747
    Points : 185
    Points
    185
    Par défaut
    J'crois que j'ai parlé un peu trop vite en fait. Le comportement est vraiment bizarre au bout de quelques secondes. Une partie de la page est "doublée".

    Cette page est une page de test (je découvre Ajax) mais lorsque je la met dans ma "vraie" page, le rafraichissement ne se fait plus.

    Voici mon code, si quelqu'un pouvait m'expliquer ce qui se passe, ce serait sympa.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    <html>
    <head>
    	<script language="javascript" type="text/javascript">
    		URL = "http://localhost/Test/test_Ajax/test.php";
    		function rafraichir() {
    				if (window.XMLHttpRequest) xhr = new XMLHttpRequest();
    				else if (window.ActiveXObject) xhr = new ActiveXObject('Microsoft.XMLHTTP');
    				else alert('JavaScript : votre navigateur ne supporte pas les objets XMLHttpRequest...');
    				xhr.open('GET',URL,true);
    				xhr.onreadystatechange = ajaxReponse;
    				xhr.send(null);
    		}
     
    		function ajaxReponse() {
    				if (xhr.readyState == 4) {
    						document.getElementById("test_refresh",true).innerHTML=xhr.responseText; 
     
     
     
     
    						var timer=setInterval("rafraichir()",1000); 
    				}
    		}
    </script>
    </head>
    <body onLoad="javascript:rafraichir();">
    <table>
    	<tr>
    		<td id="test_refresh">
    			<?php 
                            $nb_min = 1;
                            $nb_max = 100;
                            $nombre = mt_rand($nb_min,$nb_max);
                            
                            echo $nombre;
                            ?>
    		</td>
    	</tr>
    </table>	
    ceci est une première phrase<br/>ceci est une seconde phrase
    <div style="position:absolute; top:100px; left:200px; height:100px; width:200px; border:1px solid #000000">
    div test
    </div>
    </body>
    </html>
    Merci beaucoup

  5. #5
    Rédacteur

    Avatar de Bovino
    Homme Profil pro
    Développeur Web
    Inscrit en
    Juin 2008
    Messages
    23 647
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 53
    Localisation : France, Gironde (Aquitaine)

    Informations professionnelles :
    Activité : Développeur Web
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2008
    Messages : 23 647
    Points : 91 220
    Points
    91 220
    Billets dans le blog
    20
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.getElementById("test_refresh",true)
    c'est quoi ce paramètre true ?
    Pas de question technique par MP !
    Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
    Mes formations video2brain : La formation complète sur JavaScriptJavaScript et le DOM par la pratiquePHP 5 et MySQL : les fondamentaux
    Mon livre sur jQuery
    Module Firefox / Chrome d'intégration de JSFiddle et CodePen sur le forum

  6. #6
    Membre habitué
    Inscrit en
    Juillet 2006
    Messages
    747
    Détails du profil
    Informations forums :
    Inscription : Juillet 2006
    Messages : 747
    Points : 185
    Points
    185
    Par défaut
    Ben je t'avouerai que je sais pas trop Bovino. C'est un code que j'ai récupéré à la base sur le net. C'est peut-être ça qui fait que cela fait n'importe quoi. Je vais essayer ce soir.

    Merci

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Réponses: 12
    Dernier message: 28/05/2011, 12h53
  2. [AJAX] Rafraichir une partie de la page en Ajax
    Par isitien dans le forum AJAX
    Réponses: 1
    Dernier message: 11/12/2010, 05h27
  3. [AJAX] rafraichir une partie d'une page
    Par gloglo dans le forum Général JavaScript
    Réponses: 3
    Dernier message: 05/05/2008, 10h31
  4. [AJAX] Recharger une partie de la page.
    Par salmoucha dans le forum Général JavaScript
    Réponses: 1
    Dernier message: 22/04/2008, 16h42
  5. [Struts][Ajax]Rafraichir une partie d'une JSP
    Par jsl1 dans le forum Servlets/JSP
    Réponses: 6
    Dernier message: 22/02/2006, 14h09

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo