2 liste liée avec une zone de texte pour l'affichage de resultat
Fermé
debloc12
Messages postés
72
Date d'inscription
lundi 12 novembre 2012
Statut
Membre
Dernière intervention
1 juin 2013
-
7 déc. 2012 à 15:31
Alain_42 Messages postés 5361 Date d'inscription dimanche 3 février 2008 Statut Membre Dernière intervention 13 février 2017 - 10 déc. 2012 à 17:07
Alain_42 Messages postés 5361 Date d'inscription dimanche 3 février 2008 Statut Membre Dernière intervention 13 février 2017 - 10 déc. 2012 à 17:07
A voir également:
- 2 liste liée avec une zone de texte pour l'affichage de resultat
- Zone telechargement - Accueil - Outils
- Liste déroulante excel - Guide
- Gertrude a préparé la liste des affaires à prendre pour l'excursion. juliette a modifié cette liste en utilisant le mode suivi des modifications proposé par le traitement de texte. - Guide
- Liste déroulante en cascade - Guide
- Word numéro de page 1/2 - Guide
2 réponses
debloc12
Messages postés
72
Date d'inscription
lundi 12 novembre 2012
Statut
Membre
Dernière intervention
1 juin 2013
7 déc. 2012 à 15:53
7 déc. 2012 à 15:53
J'ai fait deux liste mais j'ai un problème c'est que dans la zone de texte il s'affiche l'id de model et l'id de serie voici mon code si dessous et ma base contient deux table
Table 1:model(id_model , model)
Table 2: serie(id_serie,serie,id_model)
*************
voici le code
*************
<!DOCTYPE html>
<html lang="en" dir="ltr">
<head>
<title>Debloc mag</title>
<meta charset="iso-8859-1">
<link rel="stylesheet" href="styles/layout.css" type="text/css">
<script src="scripts/jquery.1.5.1.min.js"></script>
<script type="text/javascript" src="scripts/jquery.defaultvalue.js"></script>
<script type="text/javascript" src="scripts/masquer.js"></script>
</head>
<body id="top">
<div class="wrapper row1">
<header id="header" class="clear">
<hgroup>
</hgroup>
<div id="pp1">
<?php
$date = date("d-m-Y");
$heure = date("H:i");
Print("<font color='#000000'>Le $date || $heure </font>");
?></div>
</header>
</div>
<!-- content -->
<div class="wrapper row2">
<div id="container" class="clear">
<!-- content body -->
<div id="content" align="center">
<h2 class="title" align="center">Déblocage par modèle</h2>
<?php
echo("<?xml version=\"1.0\" encoding=\"iso-8859-1\"?>\n");
/* Variables de connexion : ajustez ces paramètres selon votre propre environnement */
$serveur = "127.0.0.1";
$admin = "root";
$mdp = "";
$base = "base";
/* On récupère si elle existe la valeur de la région envoyée par le formulaire */
$idr = isset($_POST['model'])?$_POST['model']:null;
?>
<?php
if(isset($_POST['ok']) && isset($_POST['serie']) && $_POST['serie'] != "")
{
$model_selectionnee = $_POST['model'];
$serie_selectionne = $_POST['serie'];
?>
<?php
}
?>
<h3>Trouver un serie</h3>
<?php
/* On établit la connexion à MySQL avec mysql_pconnect() plutôt qu'avec mysql_connect()
* car on aura besoin de la connexion un peu plus loin dans le script */
$connexion = mysql_pconnect('127.0.0.1', 'root','');
if($connexion != false)
{
$choixbase = mysql_select_db($base, $connexion);
$sql1 = "SELECT *".
" FROM 'model'".
" ORDER BY 'id_model'";
$rech_models = mysql_query($sql1);
$code_model = array();
$model = array();
/* On active un compteur pour les régions */
$nb_models = 0;
if($rech_models != false)
{
while($ligne = mysql_fetch_assoc($rech_models))
{
array_push($code_model, $ligne['id_model']);
array_push($model, $ligne['model']);
/* On incrémente de compteur */
$nb_models++;
}
}
?>
<form action="<?php echo($_SERVER['PHP_SELF']); ?>" method="post" id="chgserie">
<fieldset style="border: 3px double #333399">
<legend>Sélectionnez un modéle</legend>
<select name="model" id="model" onChange="document.forms['chgserie'].submit();">
<option value="-1">- - - Choisissez un modéle - - -</option>
<?php
for($i = 0; $i < $nb_models; $i++)
{
?>
<option value="<?php echo($code_model[$i]); ?>"<?php echo((isset($idr) && $idr == $code_model[$i])?" selected=\"selected\"":null); ?>><?php echo($model[$i]); ?></option>
<?php
}
?>
</select>
<?php
mysql_free_result($rech_models);
/* On commence par vérifier si on a envoyé un numéro de région et le cas échéant s'il est différent de -1 */
if(isset($idr) && $idr != -1)
{
/* Cération de la requête pour avoir les départements de cette région */
$sql2 = "SELECT 'id_serie', 'serie'".
" FROM 'serie'".
" WHERE 'id_model' = ". $idr ."".
" ORDER BY 'id_serie';";
if($connexion != false)
{
$rech_serie = mysql_query($sql2, $connexion);
/* Un petit compteur pour les départements */
$nd = 0;
/* On crée deux tableaux pour les numéros et les noms des départements */
$code_serie = array();
$nom_serie = array();
/* On va mettre les numéros et noms des départements dans les deux tableaux */
while($ligne_serie = mysql_fetch_assoc($rech_serie))
{
array_push($code_serie, $ligne_serie['id_serie']);
array_push($nom_serie, $ligne_serie['serie']);
$nd++;
}
/* Maintenant on peut construire la liste déroulante */
?>
<select name="serie" id="serie">
<?php
for($d = 0; $d<$nd; $d++)
{
?>
<option value="<?php echo($code_serie[$d]); ?>"<?php echo((isset($serie_selectionne) && $serie_selectionne == $code_serie[$d])?" selected=\"selected\"":null); ?>><?php echo($nom_serie[$d]." (". $code_serie[$d] .")"); ?></option>
<?php
}
?>
</select>
<?php
}
/* Un petit coup de balai */
mysql_free_result($rech_serie);
}
?>
<br />
<input type="text" value="Série <?php echo($serie_selectionne); ?> Model <?php echo($model_selectionnee); ?>" size="30" />
<input type="submit" name="ok" id="ok" value="Envoyer" />
</fieldset>
</form>
<?php
/* Terminé, on ferme la connexion */
mysql_close($connexion);
}
else
{
/* Si on arrive là, c'est pas bon signe, il faut vérifier les
* paramètres de connexion, mot de passe, serveur pas démarré etc... */
?>
<p>Un incident s'est produit lors de la connexion à la base de données, veuiillez essayer à nouveau ultérieurement.</p>
<?php
}
?>
</div>
<!-- right column -->
<aside id="right_column">
<!-- ########################################################################################## -->
<!-- ########################################################################################## -->
<!-- ########################################################################################## -->
<!-- ########################################################################################## -->
</body>
</html>
Table 1:model(id_model , model)
Table 2: serie(id_serie,serie,id_model)
*************
voici le code
*************
<!DOCTYPE html>
<html lang="en" dir="ltr">
<head>
<title>Debloc mag</title>
<meta charset="iso-8859-1">
<link rel="stylesheet" href="styles/layout.css" type="text/css">
<script src="scripts/jquery.1.5.1.min.js"></script>
<script type="text/javascript" src="scripts/jquery.defaultvalue.js"></script>
<script type="text/javascript" src="scripts/masquer.js"></script>
</head>
<body id="top">
<div class="wrapper row1">
<header id="header" class="clear">
<hgroup>
</hgroup>
<div id="pp1">
<?php
$date = date("d-m-Y");
$heure = date("H:i");
Print("<font color='#000000'>Le $date || $heure </font>");
?></div>
</header>
</div>
<!-- content -->
<div class="wrapper row2">
<div id="container" class="clear">
<!-- content body -->
<div id="content" align="center">
<h2 class="title" align="center">Déblocage par modèle</h2>
<?php
echo("<?xml version=\"1.0\" encoding=\"iso-8859-1\"?>\n");
/* Variables de connexion : ajustez ces paramètres selon votre propre environnement */
$serveur = "127.0.0.1";
$admin = "root";
$mdp = "";
$base = "base";
/* On récupère si elle existe la valeur de la région envoyée par le formulaire */
$idr = isset($_POST['model'])?$_POST['model']:null;
?>
<?php
if(isset($_POST['ok']) && isset($_POST['serie']) && $_POST['serie'] != "")
{
$model_selectionnee = $_POST['model'];
$serie_selectionne = $_POST['serie'];
?>
<?php
}
?>
<h3>Trouver un serie</h3>
<?php
/* On établit la connexion à MySQL avec mysql_pconnect() plutôt qu'avec mysql_connect()
* car on aura besoin de la connexion un peu plus loin dans le script */
$connexion = mysql_pconnect('127.0.0.1', 'root','');
if($connexion != false)
{
$choixbase = mysql_select_db($base, $connexion);
$sql1 = "SELECT *".
" FROM 'model'".
" ORDER BY 'id_model'";
$rech_models = mysql_query($sql1);
$code_model = array();
$model = array();
/* On active un compteur pour les régions */
$nb_models = 0;
if($rech_models != false)
{
while($ligne = mysql_fetch_assoc($rech_models))
{
array_push($code_model, $ligne['id_model']);
array_push($model, $ligne['model']);
/* On incrémente de compteur */
$nb_models++;
}
}
?>
<form action="<?php echo($_SERVER['PHP_SELF']); ?>" method="post" id="chgserie">
<fieldset style="border: 3px double #333399">
<legend>Sélectionnez un modéle</legend>
<select name="model" id="model" onChange="document.forms['chgserie'].submit();">
<option value="-1">- - - Choisissez un modéle - - -</option>
<?php
for($i = 0; $i < $nb_models; $i++)
{
?>
<option value="<?php echo($code_model[$i]); ?>"<?php echo((isset($idr) && $idr == $code_model[$i])?" selected=\"selected\"":null); ?>><?php echo($model[$i]); ?></option>
<?php
}
?>
</select>
<?php
mysql_free_result($rech_models);
/* On commence par vérifier si on a envoyé un numéro de région et le cas échéant s'il est différent de -1 */
if(isset($idr) && $idr != -1)
{
/* Cération de la requête pour avoir les départements de cette région */
$sql2 = "SELECT 'id_serie', 'serie'".
" FROM 'serie'".
" WHERE 'id_model' = ". $idr ."".
" ORDER BY 'id_serie';";
if($connexion != false)
{
$rech_serie = mysql_query($sql2, $connexion);
/* Un petit compteur pour les départements */
$nd = 0;
/* On crée deux tableaux pour les numéros et les noms des départements */
$code_serie = array();
$nom_serie = array();
/* On va mettre les numéros et noms des départements dans les deux tableaux */
while($ligne_serie = mysql_fetch_assoc($rech_serie))
{
array_push($code_serie, $ligne_serie['id_serie']);
array_push($nom_serie, $ligne_serie['serie']);
$nd++;
}
/* Maintenant on peut construire la liste déroulante */
?>
<select name="serie" id="serie">
<?php
for($d = 0; $d<$nd; $d++)
{
?>
<option value="<?php echo($code_serie[$d]); ?>"<?php echo((isset($serie_selectionne) && $serie_selectionne == $code_serie[$d])?" selected=\"selected\"":null); ?>><?php echo($nom_serie[$d]." (". $code_serie[$d] .")"); ?></option>
<?php
}
?>
</select>
<?php
}
/* Un petit coup de balai */
mysql_free_result($rech_serie);
}
?>
<br />
<input type="text" value="Série <?php echo($serie_selectionne); ?> Model <?php echo($model_selectionnee); ?>" size="30" />
<input type="submit" name="ok" id="ok" value="Envoyer" />
</fieldset>
</form>
<?php
/* Terminé, on ferme la connexion */
mysql_close($connexion);
}
else
{
/* Si on arrive là, c'est pas bon signe, il faut vérifier les
* paramètres de connexion, mot de passe, serveur pas démarré etc... */
?>
<p>Un incident s'est produit lors de la connexion à la base de données, veuiillez essayer à nouveau ultérieurement.</p>
<?php
}
?>
</div>
<!-- right column -->
<aside id="right_column">
<!-- ########################################################################################## -->
<!-- ########################################################################################## -->
<!-- ########################################################################################## -->
<!-- ########################################################################################## -->
</body>
</html>
Alain_42
Messages postés
5361
Date d'inscription
dimanche 3 février 2008
Statut
Membre
Dernière intervention
13 février 2017
894
10 déc. 2012 à 17:07
10 déc. 2012 à 17:07
c'est normal tu affiches dans l'input par le php, il faut donc que suite au choix dans la liste 2 tu rappelles le script php en soumettant une deuxième fois le formulaire:
ou alors pour éviter ce deuxième appel tu fais ça en javascript:
etc...
et dans la partie <head> </head> tu rajoutes:
<select name="serie" id="serie" onChange="document.forms['chgserie'].submit();"> etc..
ou alors pour éviter ce deuxième appel tu fais ça en javascript:
<select name="serie" id="serie" onChange="eciture_input();"> //plus <option value="-1">- - - Choisissez la serie- - -</option> //etc... //ton input devient: <input type="text" id="input_resultat" value="" size="30" />
etc...
et dans la partie <head> </head> tu rajoutes:
<script type="text/javascript"> function ecrire_input(){ var input=document.getElementById('input_resultat'); var modele=document.getElementById('model'); var serie=document.getElementById('serie'); if(modele.value != "-1" && serie.value != "-1"){ input.value="Série "+serie.value+" Modele "+modele.value; } } </script>