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 27/01/2012, 09h18   #1
Invité de passage
 
Inscription : janvier 2012
Messages : 2
Détails du profil
Informations forums :
Inscription : janvier 2012
Messages : 2
Points : 0
Points : 0
Par défaut Listes liées AJAX

Bonjour à tous, j'ai un problème. J'ai suivi à la lettre ce tuto :
http://siddh.developpez.com/articles/ajax/
Mais même en ayant copié-collé tout le code (à la fin ça me soulait) ça ne fonctionne pas ! Pourtant mes identifiants MySQL sont bien les bons, les tables, les valeurs, tout est bien créé et tout le code est le même que sur le site...
Voici ce que ça me donne : http://listeliee.cwahi.net/
Ma page ajaxLivre.php :

Code :
1
2
3
4
5
6
7
8
9
10
11
12
13
<?php
	echo "<select name='livre'>";
	if(isset($_POST["idAuteur"])){
		mysql_connect("fdb-1-118.cwahi.net","pseudo","mdp");
		mysql_select_db("listeliee_db1");
		$res = mysql_query("SELECT id,titre FROM livre 
			WHERE idAuteur=".$_POST["idAuteur"]." ORDER BY titre");
		while($row = mysql_fetch_assoc($res)){
			echo "<option value='".$row["id"]."'>".$row["titre"]."</option>";
		}
	}
	echo "</select>";
?>
Et la page d'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
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
<html>
	<head>
		<title>Tutoriel Ajax (XHTML + JavaScript + XML)</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('livre').innerHTML = leselect;
					}
				}
 
				// Ici on va voir comment faire du post
				xhr.open("POST","ajaxLivre.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('auteur');
				idauteur = sel.options[sel.selectedIndex].value;
				xhr.send("idAuteur="+idauteur);
			}
		</script>
	</head>
	<body>
		<form>
			<fieldset style="width: 500px">
				<legend>Liste liées</legend>
				<label>Auteurs</label>
				<select name='auteur' id='auteur' onchange='go()'>
					<option value='-1'>Aucun</option>
					<?
						mysql_connect("fdb-1-118.cwahi.net","pseudo","mdp");
						mysql_select_db("listeliee_db1");
						$res = mysql_query("SELECT * FROM auteur ORDER BY nom");
						while($row = mysql_fetch_assoc($res)){
							echo "<option value='".$row["id"]."'>".$row["nom"]."</option>";
						}
					?>
				</select>
				<label>Livres</label>
				<div id='livre' style='display:inline'>
				<select name='livre'>
					<option value='-1'>Choisir un auteur</option>
				</select>
				</div>
			</fieldset>
		</form>
	</body>
</html>
Kerox_56 est déconnecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/01/2012, 09h31   #2
Responsable Développement Web

 
Avatar de Bovino
 
Homme Didier Mouronval
Développeur Web
Inscription : juin 2008
Messages : 13 808
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 808
Points : 35 786
Points : 35 786
Citation:
Envoyé par Kerox_56
Voici ce que ça me donne : http://listeliee.cwahi.net/
Ben... sur cette page, ta liste d'auteurs est vide, je vois pas comment le reste pourrait fonctionner...
__________________
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 actuellement connecté   Envoyer un message privé Réponse avec citation 00
Vieux 27/01/2012, 17h39   #3
Invité de passage
 
Inscription : janvier 2012
Messages : 2
Détails du profil
Informations forums :
Inscription : janvier 2012
Messages : 2
Points : 0
Points : 0
Non mais en fait, j'ai un peu modifié mon code, mais ça ne fonctionne toujours pas. Si on pouvait m'expliquer...

index.php
Citation:
<?php
require './config.inc.php';

$mysqli = new mysqli($db['server'], $db['user'], $db['passwd'], $db['name']);

if (0 !== mysqli_connect_errno()) {
exit('Could not connect to database: ' . mysqli_connect_error());
}

// Regions initiales
$sql = 'SELECT categorie_id, categorie_name FROM categorie';
?>

<script type="text/javascript" src="regions.js"></script>

<form action="submit.php" method="post" id="form">

<p>Sélectionnez une catégorie :
<select name="categorie" id="categorie" onchange="updateDepartements(this.value)">
<?php
if (FALSE !== ($res = $mysqli->query($sql))) {

while ($row = $res->fetch_assoc()) {
printf('<option value="%s">%s</option>', $row['categorie_id'], $row['categorie_name']);
}
$res->close();
}
?>
</select>
</p>

<p>Sélectionnez un produit :
<select name="produit" id="produit"></select>
</p>

<p><input type="submit" value="Soumettre" />

</form>
rpc.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
<?php
if (TRUE === isset($_GET['categorie'])) {
	$categorie = intval($_GET['categorie']);
} else {
	exit;
}
 
require './config.inc.php';
 
$mysqli = new mysqli($db['server'], $db['user'], $db['passwd'], $db['name']);
 
if (0 !== mysqli_connect_errno()) {
	exit('Could not connect to database: ' . mysqli_connect_error());
}
 
header('Content-Type: text/xml; charset=UTF-8');
 
$dom = new DOMDocument('1.0', 'utf-8');
$message = $dom->createElement('message');
$message = $dom->appendChild($message);
 
$sql = 'SELECT produit_id, produit_name ' .
       'FROM produit ' .
       'WHERE categorie_id=' . $categorie;
 
if (FALSE !== ($res = $mysqli->query($sql))) {
 
	while ($row = $res->fetch_assoc()) {
		$produit = $dom->createElement('produit', utf8_encode($row['produit_name']));
		$produit = $message->appendChild($produit);
		$produit->setAttribute('id', $row['produit_id']);
	}
	$res->close();
}
 
echo $dom->saveXML();
?>
region.js
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
var ajax;
 
try {
	ajax = new ActiveXObject("Msxml2.XMLHTTP");
} catch (e) {
	try {
		ajax = new ActiveXObject("Microsoft.XMLHTTP");
	} catch (e) {
		if (typeof XMLHttpRequest!='undefined') {
			ajax = new XMLHttpRequest();
		}
	}
}
 
function updateDepartements(categorie) {
	ajax.open('get', 'rpc.php?categorie=' + categorie);
	ajax.onreadystatechange = handleResponse;
	ajax.send(null);
}
 
function handleResponse() {
 
	if(ajax.readyState == 4) {
 
		var data = ajax.responseXML.getElementsByTagName('produit');
 
		document.getElementById('produit').innerHTML = '';
		for(var i=0;i<data.length;i++) {
 
			var option = document.createElement('option');
			option.setAttribute('value',data[i].getAttribute("id"));
			option.appendChild(document.createTextNode(data[i].firstChild.nodeValue));
			document.getElementById('produit').appendChild(option);
		}
	}
}
 
function initForm() {
	document.getElementById('categorie').selectedIndex = 0;
	updateDepartements(document.getElementById('categorie').value);
}
 
if (window.addEventListener) {
	window.addEventListener("load", initForm, false); 
} else if (window.attachEvent){ 
	window.attachEvent("onload", initForm); 
}
config.inc.php
Code :
1
2
3
4
5
6
7
8
<?php
$db = array(
	'server' => 'localhost',
	'user' => 'root',
	'passwd' => '',
	'name' => 'lavage'
);
?>
Kerox_56 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 20h46.


 
 
 
 
Partenaires

Hébergement Web