Précédent   Forum des professionnels en informatique > PHP > Langage > Formulaires
Formulaires Forum d'entraide sur les formulaires avec PHP. Avant de poster -> FAQ formulaires, Cours de formulaires et Sources de formulaires
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 28/12/2011, 15h24   #1
Invité de passage
 
Inscription : octobre 2008
Messages : 21
Détails du profil
Informations forums :
Inscription : octobre 2008
Messages : 21
Points : 0
Points : 0
Par défaut récuperer la valeur sélectionnée d'une liste

Bonjour,
qlq un peut m'aider svpppp,

j'ai une liste déroulante( "secteur") et je veux remplir une liste filière à partir de la valeur sélectionnée de la liste secteur et non par l'id sans recharger la page,
pour récupérer la valeur j'ai utilisée ajax voilà mon code

la fonction pour récupérer la valeur sélectionnée



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
			function getXhr(){
                                var xhr = null; 
				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; 
				} 
                                return xhr;
			}
 
			/**
			* Méthode qui sera appelée sur le click du bouton
			*/
			function go(){
				var xhr = 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('filier').innerHTML = leselect;
					}
				}
 
				// Ici on va voir comment faire du post
				xhr.open("POST","filiere.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
				fil=(document.getElementById('filier').options[document.getElementById('filier').selectedIndex].value);
				secteur = fil.options[fil.selectedIndex].value;
				xhr.send("Secteur="+secteur);
			}

et voilà la page filiere pour emplire la liste

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<?php 
 
include('fonction.php');
ConnectMabase();
echo "<select name='filier'>";
if(isset($_POST['Secteur'])){
		$id=$_POST['Secteur'];
		$str = str_replace("-", " ",$id); 
  $sqlclase="select DISTINCT FiliereDeFormation, Secteur from etablissement where Secteur='$str'  ORDER BY `FiliereDeFormation`";
				             $resulclase=mysql_query($sqlclase);
							 while($clase=mysql_fetch_array($resulclase))
				           {
                               $salle=$clase[0];
							   $sal=string2url($salle);
 
							echo'<option value='.$sal.'>'.$salle.'</option>';
 
						   } 
						 }				
echo "</select>";
echo "<input name=\"Rechercher\" type=\"submit\" id=\"Rechercher\"  value=\"Rechercher\" />";
 
?>

et enfin les listes dans la page index



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
       <?php                     
 
 
 
							   echo "<select name=\"nivea\" id=\"nivea\" class=\"inputaccueil\" onchange=\"go();\"  >"; 			
 
				     			$sqlniv="select DISTINCT Secteur from etablissement ORDER BY `Secteur`";
				     			$resultat=mysql_query($sqlniv);
 
 
									// echo "<option value= $selected selected=\"selected\">".str_replace("-", " ",$_GET['nivea'])."</option>";
									 echo "<option value='-1'>Choisissez un secteur</option>";
									  while($rang=mysql_fetch_array($resultat))
				      				   { 										                          					
				          			     $libelle=$rang['Secteur'];
									     $lib=$rang['Secteur'];
									     $valeur=string2url($lib);
									     echo'<option value='.$valeur.' >'.$libelle.'</option>';
									   }
									  echo "</select>";
 
 
 
 
 
 
											//$selected=($_POST['nivea']==$libelle)?'selected=\"selected\"':'';						
 
 
				              ?>  <td>    
      <?php
 
 
							    echo "<select name=\"filier\" id=\"filier\" class=\"inputaccueil\"    >"; 
           		                echo "<option value=0>Choissisez une filiere</option>" ;
 
 
						   	echo "</select>";
							    echo "</td>" ;
 
                          ?>
j'ai besoin de vos aides svppppp c'est presque une semaine que je cherche dans ce truc sans sans résultat
SISGI est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 28/12/2011, 23h39   #2
Expert Confirmé
 
Avatar de rawsrc
 
Homme Martin
Dev indep
Inscription : mars 2004
Messages : 1 462
Détails du profil
Informations personnelles :
Nom : Homme Martin
Âge : 35
Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

Informations professionnelles :
Activité : Dev indep

Informations forums :
Inscription : mars 2004
Messages : 1 462
Points : 2 552
Points : 2 552
Envoyer un message via Skype™ à rawsrc
Bonsoir,

J'ai repris ton code php en essayant de bien suivre :
les listes dans la page index :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<?php
$sql  = "SELECT DISTINCT Secteur FROM etablissement ORDER BY Secteur";
$exec = mysql_query($sql);
?>
   <select name="nivea" id="nivea" class="inputaccueil" onchange="go();">
      <option value="-1">Choisissez un secteur</option>
      <?php while($row = mysql_fetch_assoc($exec)): ?>
      <option value="<?php echo string2url($row['Secteur']); ?>"><?php echo $row['Secteur']; ?></option>
      <?php endwhile; ?>
   </select>
<td>
   <select name="filier" id="filier" class="inputaccueil">
      <option value="-1">Choissisez une filiere</option>
   </select>
</td>
la page filiere pour emplire la liste :
Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<?php
 
include('fonction.php');
ConnectMabase();
// au minimum on renvoie la 1ère ligne de la zone de liste
$render[] = '<option value="-1">Choissisez une filiere</option>';
 
if (isset($_POST['Secteur'])) {
   $secteur = str_replace("-", " ", $_POST['Secteur']);
   $sql = "SELECT DISTINCT FiliereDeFormation FROM etablissement WHERE Secteur='".mysql_real_escape_string($secteur) ."' ORDER BY FiliereDeFormation";
   $exec = mysql_query($sql);
   while($row = mysql_fetch_assoc($exec)) {
      $render[] = '<option value="'.string2url($row['FiliereDeFormation']).'">'.$row['FiliereDeFormation'].'</option>';
   }
}
echo implode("\n", $render);
?>
Je te conseille d'aller regarder mon tuto sur les listes liées en Ajax : ici. Cela devrait t'éclairer un peu.
__________________
# Dans la Création, tout est permis mais tout n'est pas utile...
rawsrc 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 02h15.


 
 
 
 
Partenaires

Hébergement Web