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

JavaScript Discussion :

[AJAX] affichage resultat XML dans div ?


Sujet :

JavaScript

  1. #1
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    240
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 240
    Points : 81
    Points
    81
    Par défaut [AJAX] affichage resultat XML dans div ?
    bonjour,

    j'ai suivi le tuto pour afficher mes info sql avec AJAX en passant par XML, mais par contre je n'arrive pas à afficher ces infos dans un DIV au lieu d'une ALERT

    voici mon code
    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
     
    <SCRIPT language="javascript">
    function ajax()
    {
        var xhr=null;
     
        if (window.XMLHttpRequest) { 
            xhr = new XMLHttpRequest();
        }
        else if (window.ActiveXObject) 
        {
            xhr = new ActiveXObject("Microsoft.XMLHTTP");
        }
        //on définit l'appel de la fonction au retour serveur
        xhr.onreadystatechange = function() { alert_ajax(xhr); };
     
        //on appelle le fichier reponse.txt
        xhr.open("GET", "reponse.php", true);
        xhr.send(null);
    }
     
    function alert_ajax(xhr)
    {
     
    	var docXML= xhr.responseXML;
    	var items = docXML.getElementsByTagName("donnee")
    	//on fait juste une boucle sur chaque élément "donnee" trouvé
    	for (i=0;i<items.length;i++)
    	{
    		alert (items.item(i).firstChild.data);
    	}
    }
    </SCRIPT>
    je pensse qu'il faut intégrer

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.getElementById(id).innerHTML= 'donnee';
    Mais ou ??? et comment ???

  2. #2
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    240
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 240
    Points : 81
    Points
    81
    Par défaut
    Je me demande si ce que je veus faire est finalement possible ....

  3. #3
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    240
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 240
    Points : 81
    Points
    81
    Par défaut
    j'ai bricolé sa :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
     
    function alert_ajax(xhr)
    {
     
    	var docXML= xhr.responseXML;
    	var items = docXML.getElementsByTagName("donnee")
    	//on fait juste une boucle sur chaque élément "donnee" trouvé
    	for (i=0;i<items.length;i++)
    	{
    		document.getElementById(affiche) (items.item(i).firstChild.data);
    	}
    }
    Mais sa ne marche toujours pas ....

  4. #4
    Membre averti
    Inscrit en
    Novembre 2006
    Messages
    336
    Détails du profil
    Informations forums :
    Inscription : Novembre 2006
    Messages : 336
    Points : 374
    Points
    374
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    function alert_ajax(xhr)
    {
     
    	var docXML= xhr.responseXML;
    	var items = docXML.getElementsByTagName("donnee");
    	var affiche = document.getElementById("affiche");
    	//on fait juste une boucle sur chaque élément "donnee" trouvé
    	for (i=0;i<items.length;i++)
    	{
    		 affiche.innerHTML += items.item(i).firstChild.data;
    		 //affiche.innerHTML += items[i].firstChild.data;
    	}
    }
    Dans la variable affiche, je récupère une réference à l'element qui à l'id affiche.
    Note que je stocke cette variable en dehors de la boucle, histoire d'éviter d'appeller la fonction getElementById x fois alors que c'est le même élement que je manipule.
    Ensuite dans la boucle, j'ai commenté une ligne, c'est l'équivalence à celle du haut en plus simple

    Il manquait l'affectation de innerHTML dans ton code, je l'ai rajouté.

    Sinon, dépendant du navigateur, tu peux avoir des suprises puisque firefox compte les retours de chariots comme des noeuds.

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Juillet 2007
    Messages
    240
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2007
    Messages : 240
    Points : 81
    Points
    81
    Par défaut
    Merci, j'ai réussi à intégrer le code parfaitement tout marche trés bien

    Par contre est il possible de spécifier dans le xml l'affichage d'une image et d'un lien, écrire du html en quelque sorte, car je n'arrive pas à comprendre le roll de xml simple liste de donnée ???

    sinon est il possible d'exploiter ses données pour les traiter ensuite dans des balises html pour les structurers

  6. #6
    Membre actif
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    372
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 372
    Points : 239
    Points
    239
    Par défaut
    J'ai essayé ton code en version "adaptée" mais chez moi ca ne marche pas....

    J'ai un objet :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    xmlData=request.responseXML;
    Et je modifie des trucs dans ce fichier (valeur de l'attribut "visibility" des tags "g")....
    Mais apres quand je faic ceci :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    var items = xmlData.getElementsByTagName("g")
    	//on fait juste une boucle sur chaque élément "g" trouvé
    	for (i=0;i<items.length;i++)
    	{
    		alert (items.item(i).firstChild.data);
    	}
    J'ai bien 6 alert (j'ai 6 balises g dans mon fichier xml), mais par malheur le text des alert est la chaine de character vide : "". Si jamais je fais :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    var items = xmlData.getElementsByTagName("g")
    	//on fait juste une boucle sur chaque élément "g" trouvé
    	for (i=0;i<items.length;i++)
    	{
    		alert (items.item(i).firstChild);
    	}
    Alors j'ai 6 alerts disant la même chose : "[object Text]"

    ...

    Une idée de pourquoi?

  7. #7
    Membre actif
    Profil pro
    Inscrit en
    Juillet 2006
    Messages
    372
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Juillet 2006
    Messages : 372
    Points : 239
    Points
    239
    Par défaut
    j'ai trouvé pas mal de trucs sur ce site qui m'on permis de résoudre le pb

Discussions similaires

  1. affichage page.php dans div
    Par fasyr dans le forum Général JavaScript
    Réponses: 41
    Dernier message: 29/05/2009, 13h05
  2. [RELATIONS]Affichage resultat relation dans DATAGRIDVIEW
    Par stephane77fr dans le forum Windows Forms
    Réponses: 1
    Dernier message: 12/07/2007, 16h41
  3. affichage resultat correlation dans excel
    Par oliver75 dans le forum Macros et VBA Excel
    Réponses: 6
    Dernier message: 04/07/2007, 11h12
  4. [AJAX] Insertion page web dans div.
    Par viinceent dans le forum Général JavaScript
    Réponses: 2
    Dernier message: 30/05/2007, 11h19
  5. Réponses: 13
    Dernier message: 14/06/2004, 15h35

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