Précédent   Forum des professionnels en informatique > Webmasters - Développement Web > AJAX
AJAX Forum sur la programmation AJAX. Avant de poster : Cours AJAX, FAQ AJAX, Toutes les FAQ JavaScript
Partagez cette discussion sur d'autres réseaux sociaux : Viadeo Twitter Google Facebook Digg Delicious MySpace Yahoo
Réponse Proposer ce sujet en actualité
 
Outils de la discussion
Publicité
'
Vieux 20/03/2011, 14h42   #1
Invité de passage
 
Romain Tiennot
Inscription : novembre 2010
Messages : 10
Détails du profil
Informations personnelles :
Nom : Romain Tiennot

Informations forums :
Inscription : novembre 2010
Messages : 10
Points : 0
Points : 0
Par défaut Réinitialisation de la troisième liste

Bonjour,

J'essaye de mettre en place trois liste liées.
J'obtiens bien un résultat sur les trois listes mais après avoir selectionné un champs dans chaque liste et que je modifie la premiere, la derniere liste ne se reinitialise pas (elle garde la valeur).
Voici l'exemple en quesiton : http://tiennot.fr/tutoajax/genre.php

genre.php :

Code :
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
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
<html>
	<head>
		<title>Tutoriel Ajax (XHTML + JavaScript + XML)</title>
		<script type='text/javascript'>
			var xhr = null; 
 
			function getXhr(){
				if(window.XMLHttpRequest) // Firefox et autres
				   xhr = new XMLHttpRequest(); 
				else if(window.ActiveXObject){ // Internet Explorer 
				   try {
			                xhr = new ActiveXObject("Msxml2.XMLHTTP");
			            } catch (e) {
			                xhr = new ActiveXObject("Microsoft.XMLHTTP");
			            }
				}
				else { // XMLHttpRequest non supporté par le navigateur 
				   alert("Votre navigateur ne supporte pas les objets XMLHTTPRequest..."); 
				   xhr = false; 
				} 
			}
 
			/**
			* Méthode qui sera appelée sur le click du bouton
			*/
			function go(){
				getXhr();
				// On défini ce qu'on va faire quand on aura la réponse
				xhr.onreadystatechange = function(){
					// On ne fait quelque chose que si on a tout reçu et que le serveur est ok
					if(xhr.readyState == 4 && xhr.status == 200){
						leselect = xhr.responseText;
						// On se sert de innerHTML pour rajouter les options a la liste
						document.getElementById('espece').innerHTML = leselect;
					}
				}
 
				// Ici on va voir comment faire du post
				xhr.open("POST","Ajaxespece.php",true);
				// ne pas oublier ça pour le post
				xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
				// ne pas oublier de poster les arguments
				// ici, l'id de l'auteur
				sel = document.getElementById('genre');
				idgenre = sel.options[sel.selectedIndex].value;
				xhr.send("idGenre="+idgenre);
			}
			function goesp(){
				getXhr();
				// On défini ce qu'on va faire quand on aura la réponse
				xhr.onreadystatechange = function(){
					// On ne fait quelque chose que si on a tout reçu et que le serveur est ok
					if(xhr.readyState == 4 && xhr.status == 200){
						leselect2 = xhr.responseText;
						// On se sert de innerHTML pour rajouter les options a la liste
						document.getElementById('variete').innerHTML = leselect2;
					}
				}
 
				// Ici on va voir comment faire du post
				xhr.open("POST","Ajaxvariete.php",true);
				// ne pas oublier ça pour le post
				xhr.setRequestHeader('Content-Type','application/x-www-form-urlencoded');
				// ne pas oublier de poster les arguments
				// ici, l'id de l'auteur
				sel = document.getElementById('espece2');
				idesp = sel.options[sel.selectedIndex].value;
				xhr.send("idEsp="+idesp);
			}
		</script>
	</head>
	<body>
		<form>
			<fieldset style="width: 500px">
				<legend>Liste liées</legend>
				<select name='genre' id='genre' onchange='go()'>
					<option value='-1'>--Nom du Fabriquant --</option>
							<?
mysql_connect("XX","XX","XX");
		mysql_select_db("XX");
						$res = mysql_query("SELECT DISTINCT fabriquantAiguille FROM aiguille ORDER BY fabriquantAiguille");
						while($row = mysql_fetch_assoc($res)){
							echo "<option value='".$row["fabriquantAiguille"]."'>".$row["fabriquantAiguille"]."</option>";
						}
					?>
				</select>
				<div id='espece' style='display:inline'>
				<select name='espece'>
					<option value='-1'>-- Numero du Lot --</option>
				</select>
				</div>
				<div id='variete' style='display:inline'>
				<select name='variete'>
					<option value='-1'>-- Numero de l'Aiguille --</option>
				</select>
				</div>
			</fieldset>
		</form>
	</body>
</html>
Ajaxespece :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
<?php
 $idAuteur=$_POST['idGenre'];
	if(isset($_REQUEST["idGenre"])){
		mysql_connect("XX","XX","XX");
		mysql_select_db("XX");
		$res = mysql_query("SELECT * FROM aiguille WHERE fabriquantAiguille='$idAuteur' ORDER BY lotAiguille ");
		echo "<select name='espece2'  id='espece2' onchange='goesp()'>";
		echo "<option value='-1'>-- Numero du Lot --</option>";
		while($row = mysql_fetch_assoc($res)){
			echo "<option value='".$row["lotAiguille"]."'>".$row["lotAiguille"]."</option>";
		}
	}
?>

Ajaxvariete :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<?php
  $idLivre=$_POST['idEsp'];
	echo "<select id='variete' name='variete'>";
	if(isset($_REQUEST["idEsp"])){
		mysql_connect("XX","XX","XX");
		mysql_select_db("XX");
		$res = mysql_query("SELECT * FROM aiguille WHERE lotAiguille='$idLivre' ORDER BY typeAiguille");
		echo "<option value='-1'>-- Numero de l'Aiguille --</option>";
		while($row = mysql_fetch_assoc($res)){
			echo "<option value='".$row["typeAiguille"]."'>".$row["typeAiguille"]."</option>";
		}
	}
	else
		echo "<option value='-1'>Choisir un auteur</option>";
	echo "</select>";
 
?>
Cordialement
Romain
aikiox est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 21/03/2011, 08h31   #2
Responsable Développement Web

 
Avatar de Bovino
 
Homme Didier Mouronval
Développeur Web
Inscription : juin 2008
Messages : 13 805
Détails du profil
Informations personnelles :
Nom : Homme Didier Mouronval
Âge : 41
Localisation : France, Gironde (Aquitaine)

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

Informations forums :
Inscription : juin 2008
Messages : 13 805
Points : 35 807
Points : 35 807
Citation:
après avoir selectionné un champs dans chaque liste et que je modifie la premiere, la derniere liste ne se reinitialise pas
Et selon toi, à quel moment tu demandes à ton script de le faire ?
__________________
Pas de question technique par MP !
Tout le monde peut participer à developpez.com, vous avez une idée, contactez-moi !
Vous possédez un blog et aimeriez diffuser vos billets sur le forum, 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
Bovino est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/03/2011, 14h52   #3
Invité de passage
 
Romain Tiennot
Inscription : novembre 2010
Messages : 10
Détails du profil
Informations personnelles :
Nom : Romain Tiennot

Informations forums :
Inscription : novembre 2010
Messages : 10
Points : 0
Points : 0
Justement à aucun moment. C'est pour cela que j'aimerais avoir de l'aide pour que l'on m'indique où et quoi lui indiquer...
aikiox est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 30/03/2011, 13h45   #4
Membre habitué
 
Inscription : septembre 2009
Messages : 85
Détails du profil
Informations personnelles :
Âge : 22
Localisation : France, Isère (Rhône Alpes)

Informations forums :
Inscription : septembre 2009
Messages : 85
Points : 101
Points : 101
Citation:
J'obtiens bien un résultat sur les trois listes mais après avoir selectionné un champs dans chaque liste et que je modifie la premiere, la derniere liste ne se reinitialise pas
je décompose ton probleme comme ca:
LORSQUE je modifie la première
ALORS La dernière liste ne se réinitialise pas.

donc lors de ton évènement onChange de la première liste, re-initialise ta dernière liste comme lors de ton chargement de la page.
gototog est déconnecté   Envoyer un message privé Réponse avec citation 00
Réponse Proposer ce sujet en actualité
Outils de la discussion



Fuseau horaire GMT +2. Il est actuellement 20h14.


 
 
 
 
Partenaires

Hébergement Web