Rechercher : dans
Par :

Afficher un tableau sans recharger la page

Dernière réponse le 1 oct 2009 à 15:43:42 wapette21, le 1 oct 2009 à 11:29:38 
 Signaler ce message aux modérateurs

Bonjour,

Je voudrais savoir si il est possible d'afficher un tableau en fonction d'un select sans changer de page (dynamiquement).

exemple :

<select name='table' onChange='affichetable()'><option>table1</option><option>table2</option></select>

echo $table;

Je ne sais pas trop comment faire.

Merci

Configuration: Windows XP
Firefox 3.0.11

Meilleures réponses pour « Afficher un tableau sans recharger la page » dans :
Trier un tableau sans utiliser la fonction sort VoirTrier un tableau sans utiliser la fonction sort D'abord on initialise une variable $max avec la 1ère valeur de tableau. Ensuite on va faire une boucle tant que le tableau contient encore des éléments. C'est avec la fonction splice qui a le rôle...
Publier un fichier PDF sur son site VoirSommaire: Publier un PDF sur son site Conseils Afficher un PDF intégré à une page Téléchargement Convertir un PDF en SWF (Flash) Publier le SWF Astuces et conseils Publier un PDF sur son site Publier un fichier PDF en ligne est en...
Javascript - L'objet window VoirLes particularités de l'objet window L'objet window est l'objet par excellence dans Javascript, car il est le parent de chaque objet qui compose la page web, il contient donc : l'objet document: la page en elle-même l'objet location: le lieu de...

1

Alain_42, le 1 oct 2009 à 11:58:14

Sans recharger la page, la solution c'est Ajax

ç'est une fonction javascript/ajax qui sur le onChange appelle un script php sur le serveur, en lui passant en argument le choix liste1 , ce script va lire dans une BDD et renvoie la réponse.
cette réponse lorsqu'elle est reçue par le script Ajax est "écrite" ou tu veux dans un <div id="reponse"></div> dans ta page par

document.getElementById("reponse").innerHTML=la_reponse_a_la_requette

et tout ça sans recharger la page

Répondre à Alain_42

2

kij_82, le 1 oct 2009 à 11:58:26

Bonjour,

Bien sur, c'est tout à fait réalisable avec javascript et PHP.

Je vois que tu souhaites affichés différemment ta table selon ce qui est sélectionnée. Ce qui veut donc dire que tu devra faire appel à du PHP qui ira chercher les informations de ta table en fonction de la sélection pour ensuite modifié sans rechargement ta table dans ta page.

Une solution est d'utiliser Ajax et les objets XHR. Pour comprendre leur fonctionnement, je t'invite à parcourrir cette astuce et appliquer le système à ton cas :
http://www.commentcamarche.net/faq/sujet-18745-utilisation-d­e-l-objet-xmlhttprequest

Ensuite, une fois que tu as commencé, si tu as le moindre problème (après un minimum de réflexion si possible ^^), tu peux toujours poser tes questions techniques ici pour qu'on y réponde.

Edit: Alain plus rapide :p, ce que dit Alain est détaillé dans l'astuce si tu veux y jeter un coup d'oeil, avec un exemple normalement.

~ N'oubliez pas la balise "Résolu" lorsque votre problème est... résolu :)    ~

Répondre à kij_82

3

watou, le 1 oct 2009 à 12:05:35

<select name='table' onChange='affichetable()'>
         <option>table1</option>
         <option>table2</option>
</select>
<div id='champ'><div>   // tu va ecrire dynamiquement à cet endroit !!

la fonction affichetable() !!
function affichetable()
{
var code='<table>';
code += <tr><td>.....</td>...............</tr>
.......
code += '</table>';
// j'espere que tu as compris !!
//tu ecris le code html de ta table sous forme d'une chaine de caractères !

// puis tu l'inseres dans l'emplacement de la balise <div> !!
document.getElementById("champ").innerHTML = code;
} Le monde ne sera pas détruit par ceux qui font le mal, mais par ceux qui les regardent sans rien faire.

Répondre à watou

4

wapette21, le 1 oct 2009 à 14:12:58

Merci a vous deux, je vais regarder cette astuce.

Répondre à wapette21

5

wapette21, le 1 oct 2009 à 14:17:57

Re Bonjour,

Je viens de finir la doc, le seul problème c'est que les donnée sont stocker en base si je souhaite selon la valeur du select faire un include ("toto.php") c'est toujours possible ?

Merci

Répondre à wapette21

6

Alain_42, le 1 oct 2009 à 14:26:31

si je souhaite selon la valeur du select faire un include ("toto.php") c'est toujours possible ?

sans ajax non car un include c'est du php et php = rechargement page

par contre en Ajax, le script php appelé peut très facilement lire les données dans ta base correspondant à la valeur sélectionnée et renvoyer le résultat qui sera affiché dans ta page par Ajax/reponse

Répondre à Alain_42

7

wapette21, le 1 oct 2009 à 15:00:19

Il est peut etre possible de recharger la page sur un onclick du selecte avec un variable pour affiche un tableau deja définit dans une condition ?

exemple : http://assfootnco.free.fr/exemple.JPG

Je voudrais changer le tableau en fonction de la valeur du select.

Merci

Répondre à wapette21

8

Alain_42, le 1 oct 2009 à 15:18:57
  • +1

Voilà avec rechargement de la page, mais la valeur selectionnée dans la liste est conservée lors de l'affichage deuxième fois

<?php
//le script s'appelle lui même, on recupere les valeurs postées lorsqu'il y a changement dans la liste
if(isset($_POST['liste1']){
	$choix=$_POST['liste1'];
}else{
	$choix="";
}
?>
<html>
<form name="form1" method="post" action="<?php echo $_SERVER['PHP_SELF']; ?>">
<select name="liste1" onChange="submit();">
<option value="-1" <?php if($choix=="-1") echo "selected"; ?>>Choisissez</option>
<!-- la condition if permet de conserver le choix lors du deuxieme affichage  -->
<option value="4-3-3" <?php if($choix=="4-3-3") echo "selected"; ?> >4-3-3</option>
<option value="4-4-2" <?php if($choix=="4-4-2") echo "selected"; ?>>4-4-2</option>
</select>
</form>
<?php
//la on va inclure tes tableaux en fonction des choix
if(isset($_POST['liste1']){
	switch ($choix){
		case "4-3-3":
			include "tableau1.jpg"; //ce que tu veux
		break;
		case "4-4-2":
			include "tableau2.jpg"; //ce que tu veux
		break;
		case "-1":
			echo "Vous devez choisir une valeur !";
		break;	
	}
}
?>
</html>


attention il faut absolument une ligne choisissez pour avoir un changement de selection dans tous les cas

Répondre à Alain_42

9

kij_82, le 1 oct 2009 à 15:20:11

Deux solutions donc :

- soit tu charges déjà toutes tes données dans ta page sous forme de javascript, auquel cas les donnes seront visible dans le navigateur
- soit tu utilise de l'ajax, ce qui te permettra de requête un script PHP de manière transparente pour l'utilisateur, afin d'exécuter du code javascript en retour du script PHP afin de rafraichir ta page.

C'est peut etre un peu complexe comme ça l'ajax, mais c'est relativement facile quand tu as compris le principe.
Mais pour ça, encore faut-il que tu lise les liens qu'on donne...

Nous ne sommes pas là pour faire le travail à ta place, juste pour t'aiguiller, voir réellement t'aider si tu coince sur quelque chose de technique.

~ N'oubliez pas la balise "Résolu" lorsque votre problème est... résolu :)    ~

Répondre à kij_82

10

 wapette21, le 1 oct 2009 à 15:43:42

Super la méthode d'alain me vas bien, en ce qui concerne l'utilisation de ajax j'ai pas tout a fait compris mais ca reste un peu complique pour une première expérience cependant je vais mis mettre pour optimisé certain partie de mon dev par la suite.

Merci a vous

A+

Répondre à wapette21