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] IE me coupe ume partie du code HTML renvoyé par AJAX


Sujet :

JavaScript

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    C_C
    C_C est déconnecté
    Membre confirmé
    Inscrit en
    Novembre 2005
    Messages
    139
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 139
    Par défaut [AJAX] IE me coupe ume partie du code HTML renvoyé par AJAX
    Salut,

    J'ai sur ma page deux listes où les résultats de la seconde dépendent de ce qui est sélectionné dans la premiére. Pour cela j'ai une fonction ajax qui fonctionne bien sur firefox mais pas sur IE.
    Ce qui arrive c'est que dans le innerHTML, sur IE, la fonction ajax ne met pas tout le code HTML que je veux.
    Au lieu de metre ce code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <option value="1">texte a mettre ici</option>
    Elle met juste celui-ci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    texte a mettre ici</option>

    Voici ma fonction Ajax
    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
    46
    47
    48
    49
    50
    51
    52
    function updateSpecie()
    {	
     
       		var xhr_object = null;			
    		try
    		{
    		  // Firefox, Opera 8.0+, Safari
    		  xhr_object=new XMLHttpRequest();
    		}
    		catch (e)
    		{
    		  // Internet Explorer
    		  try
    		  {
    			  xhr_object=new ActiveXObject("Msxml2.XMLHTTP");
     
    		  }
    		  catch (e)
    		  {
    			  try
    			  {
    				  xhr_object=new ActiveXObject("Microsoft.XMLHTTP");
    			  }
    			  catch (e)
    			  {
    				  alert("Your browser don't support AJAX!");
    				  return false;
    			  }
    		   }
    		}
    		xhr_object.open("POST", "actions/update.php", true);
     
    		xhr_object.onreadystatechange = function()
    		{
     
    			if(xhr_object.readyState == 4)
    			{
    				alert(xhr_object.responseText);
    		  		document.getElementById("species").innerHTML = xhr_object.responseText;
     
    			}
     
     
    	   	}
     
    		xhr_object.setRequestHeader("Content-type", "application/x-www-form-urlencoded"); 
    	    var data = "type="+escape(list.options[index].value);
     
    	    xhr_object.send(data);
     
    	}
    }
    Et la partie du code HTML qui doit être changée:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
     
    <tr>
         <td>Espèces:</td>
         <td>
              <select id="species">
                  <option value="-1"></option>
               </select>
          </td>
    </tr>
    Est-ce que quelqu'un a une idée de ce qu'il faut faire pour corriger cela?

    Merci d'avance.

  2. #2
    Rédacteur
    Avatar de _Mac_
    Profil pro
    Inscrit en
    Août 2005
    Messages
    9 601
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 9 601
    Par défaut
    Ce que tu reçois de la page actions/update.php, c'est du vrai XML bien formé ?

  3. #3
    C_C
    C_C est déconnecté
    Membre confirmé
    Inscrit en
    Novembre 2005
    Messages
    139
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 139
    Par défaut
    Oui le XML est bien formé.
    Voici le code du fichier actions/update.php qui renvoi le code.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
     
    if(sizeof($species)>0)
    {
            echo "<option value=\"\"></option>";
    	foreach($species as $row)
    		echo "<option value=\"".$row->id."\">".$row->name."</option>";
    }

  4. #4
    Rédacteur
    Avatar de _Mac_
    Profil pro
    Inscrit en
    Août 2005
    Messages
    9 601
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 9 601
    Par défaut
    Comment tu sais que ton code Ajax ne mets que "texte a mettre ici</option>" au lieu de "<option value="1">texte a mettre ici</option>" ? Tu as fait un alert(xhr_object.responseText) pour vérifier ce que reçoit IE ? Tu peux nous montrer ce que ça affiche ? Il manque peut-être l'entête XML <?xml ...?>

  5. #5
    C_C
    C_C est déconnecté
    Membre confirmé
    Inscrit en
    Novembre 2005
    Messages
    139
    Détails du profil
    Informations forums :
    Inscription : Novembre 2005
    Messages : 139
    Par défaut
    En effet le xhr_object.responseText n'a pas l'entête xml mais est-ce qu'il doit l'avoir?
    J'ai fait des alert pour voir ce que cela renvoyait et pour alert(xhr_object.responseText) j'ai ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    <option value=""></option>
    <option value="1">abcd</option>
    <option value="2">efgh</option>
    Lá tout va bien.
    Après, dans ma fonction ajax j'ai cette ligne de code:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    document.getElementById("species").innerHTML = xhr_object.responseText;
    Et après cette ligne je fait un nouveau alert ao innerHTML:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    alert(document.getElementById("species").innerHTML);
    Et j'obtiens cela:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    abcd</option><option value="2">efgh</option>
    Comme on peut voir, il y a bout du code HTML qui a disparu.

  6. #6
    Rédacteur
    Avatar de _Mac_
    Profil pro
    Inscrit en
    Août 2005
    Messages
    9 601
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Août 2005
    Messages : 9 601
    Par défaut
    C'est plutôt ballot, en effet. Tu peux essayer en ajoutant l'en-tête XML ?

    Fais aussi un alert(document.getElementById("species").innerHTML) avant de le changer, pour voir

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

Discussions similaires

  1. Inclure parties de code html dans page html
    Par ludowag dans le forum Balisage (X)HTML et validation W3C
    Réponses: 1
    Dernier message: 13/11/2015, 18h02
  2. [AJAX] Executer code javascript écrit par ajax
    Par socket77 dans le forum AJAX
    Réponses: 1
    Dernier message: 23/12/2009, 08h13
  3. Parties de code HTML non générées
    Par sovitec dans le forum ASP.NET
    Réponses: 0
    Dernier message: 06/02/2009, 15h05
  4. Masquer une partie du code HTML selon une variable ?
    Par ghohm dans le forum Servlets/JSP
    Réponses: 2
    Dernier message: 17/09/2008, 17h51
  5. [MySQL] Récupérer Code HTML généré par PHP
    Par @ngelofdeath dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 26/04/2006, 21h51

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