Rechercher : dans
Par :

2 select Onchange ajax

Dernière réponse le 11 avr 2009 à 01:06:37 hsouna01, le 10 avr 2009 à 02:31:23 
 Signaler ce message aux modérateurs

Bonjour,
j'ai un projet de fin d'etude un site web en cour de realisation ,dans la partie administration de ce site dans l'un de ces page je veut afficher 2 select dynamique liee dans l'un qui contient la liste des filiere sporitve(volley ball,judo,foot ball) affichee de la table filiere et l'autre la liste des categorie(minim,cadee,junior,senior) selon le choix de la filiere de la table categorie pour afficher enfin les joueur ou l'entrenneur de cette categorie.
je developpe avec php et sql.

-- Structure de la table `filiere`
--

CREATE TABLE `filiere` (
`idfil` int(3) NOT NULL auto_increment,
`typefil` varchar(30) NOT NULL,
PRIMARY KEY (`idfil`),
UNIQUE KEY `typefil` (`typefil`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=116 ;

-- Structure de la table `galerie`
--

CREATE TABLE `galerie` (
`idfich` int(3) NOT NULL auto_increment,
`idfil` int(3) NOT NULL,
`nomfich` varchar(50) NOT NULL,
`urlfich` varchar(100) NOT NULL,
`typefich` varchar(30) NOT NULL,
PRIMARY KEY (`idfich`)
) ENGINE=MyISAM DEFAULT CHARSET=latin1 AUTO_INCREMENT=5 ;

--


j'ai suivit un tutorial sur le net mais malheureusement j'ai pas reussi a faire cette astuce car je ne maitrise pas bien la technologie ajax.
voici le code de deux page .php

select.php
<html>
<head>
<title>liste</title>
<script type='text/javascript'>
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('categorie').innerHTML =
leselect;
}
}
// Ici on va voir comment faire du post
xhr.open("POST","ajax.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('filiere');
filiere = sel.options[sel.selectedIndex].value;
xhr.send("filiere="+filiere);
}
</script>
</head>
<body>
<form >



<fieldset style="width: 500px">
<legend>Liste liées</legend>
<label>Auteurs</label>
<select name="filiere" id="filiere" onchange="go()">
<option value='-1'>Aucun</option>
<?php
$typefil=$_POST['filiere'];
mysql_connect("localhost","root","");
mysql_select_db("asptt");
$res = mysql_query("SELECT * FROM filiere ");
while($row = mysql_fetch_assoc($res)){?>
<option ><?php echo $row['typefil']; ?></option><?php }?>

</select>
<label>categorie</label>
<div id="categorie">
<select name="categorie">
<option value="-1">Choisir une filiere</option>
</select>
</div>
</fieldset>
</form>
</body>
</html>


ajax.php
<?php
echo "<select name='categorie' id='categorie'>";
if(isset($idfil))
{
mysql_connect("localhost","root","");
mysql_select_db("asptt");
$res = mysql_query("SELECT idcat,nomcat FROM categorie
WHERE typefil='$filiere'")or die(mysql_error());
while($row = mysql_fetch_assoc($res)){?>

<option value="<?php echo $row['idcat'] ;?>"><?php echo $row['nomcat'];?></option>
<?php }
}
echo "</select>";
?>


s'il y a quelqu'un qui peut m'aider et merci d'avance

Configuration: Windows XP
Safari 525.19

Meilleures réponses pour « 2 select Onchange ajax » dans :
[Logiciel libre] Installation firefox 2.0+java+flash VoirInstallation firefox 2.0+java+flash en ligne de commande A. INTRODUCTION B. INSTALLATION FIREFOX 1. Création d'environnement 2. Téléchargement et vérification de la signature 3. Installation de Firefox 4. Démarrage de l'application C....
[Gravure] Je n'arrive pas à graver un fichier de plus de 2 Go ! VoirLe problème Quand vous gravez un DVD, c'est généralement le format ISO-9660 qui est utilisé (que ce soit dans Nero ou tout autre logiciel de gravage). Or le format ISO-9660 ne supporte pas les fichiers de taille supérieure à 2 Go. Si vous...
Télécharger Microsoft .NET Framework 2.0 (x86) VoirLe package redistribuable de Microsoft .NET Framework 2.0 installe le runtime .NET Framework et les fichiers associés requis pour l'exécution d'applications développées pour le .NET Framework 2.0. Le .NET Framework 2.0 fournit une évolutivité et...
J2EE - Java 2 Enterprise Edition VoirIntroduction au Java Framework Le «Java Framework» (Java 2 Platform) est composé de trois éditions, destinées à des usages différents : J2ME : Java 2 Micro Edition est prévu pour le développement d'applications embarquées, notamment sur des...
Connecteur PS/2 VoirConnecteur PS/2 Le connecteur PS/2 (au format mini-DIN6) est principalement utilisé sur les ordinateur pour la connexion du clavier et de la souris. Brochage Broche Désignation 1 Horloge 2 Masse 3 ...
AJAX (Asynchronous Javascript And XML) VoirIntroduction à AJAX AJAX (Asynchronous Javascript And XML, traduisez Javascript asynchrone et XML) est une méthode de développement web basée sur l'utilisation d'un script Javascript pour effectuer des requêtes web à l'intérieur d'une page web...

1

 hsouna01, le 11 avr 2009 à 01:06:37

Salut,il n'ya pas quelqu'un qui peut m'aider,je suis bloqué.
merci d'avance.
cordialement.

Répondre à hsouna01