Rechercher : dans
Par :

[PHP] Formulaire dynamique recuperation var

Dernière réponse le 23 oct 2007 à 22:58:19 tkz, le 21 oct 2007 à 18:52:33 
 Signaler ce message aux modérateurs

Bonjour, j'ai crée un formulaire dynamique qui remplit un tableau dont le nombre de lignes depend du nombres d'occurences dans ma BDD mysql. Chaque case du tableau contient plusieurs inputs remplis des valeurs. Le but etant de modifier dans la BDD tout les champs en meme temps.

Voici mon tableau :


echo"<form method='POST' action='mod.php' enctype='multipart/form-data'>";
$total=requete('select chref from `references`;'); // total des enregistrements
$nb=mysql_num_rows($total);
$rows=round($nb/4); //nombre de lignes qui affichent 4 refs
$lim=0; //separation des resultats en lignes
echo "<table>";
for($i=0; $i< $rows+1; $i++) //pour i, i de 0 a x nombre de lignes
{
echo"<tr><td>";
$requete="select id_ref, chref, lienref, nomref, ordre from `references` order by ordre limit 4 offset ".$lim.";";
$req=requete($requete);
while($res=mysql_fetch_object($req))
{
for($j=0; $j< 3; $j++) //pour j,j de 1 a 4 enregistrements par ligne
{
$array[$j]=array(
'0'=> $res->chref,
'1'=> $res->nomref,
'2'=> $res->lienref,
'3'=> $res->ordre,
'4' => $res->id_ref
);
$id=$array[1][4];
$case="<table><tr><td><img src='".$array[1][0]."' width='75' height='75'></img></td><tr>
<tr><td><a href='ajout.php?n=$name&u=$url&m=1&i=$id'>Modifier l'image</a></td></tr>
<tr><td><input size='25' maxlenght='50' name='".$array[1][1]."' value='".$array[1][1]."'></td></tr>
<tr><td><input size='25' maxlenght='50' name='".$array[1][2]."' value='".$array[1][2]."'></td></tr>
<tr><td>Position :<input size='1' maxlenght='3' name='".$array[1][3]."' value='".$array[1][3]."'></td></tr>
<tr height='10'><td></td></tr></table>";
}
echo "<td>".$case."</td>";
}
$lim=$lim+4; // on incremente pour la requete suivante
}
echo"</tr></table>";
echo"<table><tr><td width='727'><input type='submit' value='Modifier'></td></tr></table>";

Lorsque je veux recuperer la valeur des inputs :
foreach ( $array as $var )
{
echo $array[1][1];
}
m'affiche seulement la valeur du dernier input, autant de fois qu'il ya de cases remplies sur la derniere ligne du tableau... pas convaincant...
Dois je utiliser une autre boucle ? Ou bien ajouter un attribut dans mes inputs ( id ou un hidden) et laisser 'name' statique ?

Je continue a chercher des solutions, mais je vous remercie beaucoup si vous pouvez m'aider un peu !!!

Configuration: Windows XP
Firefox 1.5.0.10

Meilleures réponses pour « [PHP] Formulaire dynamique recuperation var » dans :
[PHP] Upload de fichiers VoirLe langage PHP permet de gérer des fichiers envoyés (uploadés) grâce à un formulaire HTML. Formulaire d'envoi de fichiers Configuration de PHP pour permettre l'upload Récupération du fichier avec PHP Formulaire d'envoi de fichiers La...
[Webmaster] Un formulaire de contact pour votre site VoirCe formulaire permet d'avoir une page pour être contacté sur son site, sans utiliser de logiciel de messagerie. La personne qui vous contacte indique son adresse, l'objet du message et son message (évidemment). Le code est une version...
PHP - Récupération de données VoirPHP rend très simple la récupération de données envoyées par l'intermédiaire de formulaires HTML. Création d'un formulaire Grâce à la balise FORM du langage HTML, il est très simple de créer des formulaires comprenant : des champs de saisie des...

1

bbar, le 22 oct 2007 à 18:02:52

Salut,
à première vue, ça vient de la variable que tu utilises pour l'affichage dans ton foreach : c'est pas $array qui change mais $var. c'est donc elle qu'il te faut utiliser pour ton echo. Essaye ça et dis moi si ça ne fonctionne toujours pas correctement

Répondre à bbar

2

tkz, le 23 oct 2007 à 12:48:03

Salut, merci pour ta reponse, j'ai reussi finalement a recuperer mes post en contournant le probleme. J'ai ajouté un bouton modifier dans chaque case, meme si c'est pas top au niveau graphique.

//reprise du code du premier message
$id=$array[1][4];
$case="<form method='POST' action='mod.php?c=$id'><table>
<tr><td><img src='".$array[1][0]."' width='75' height='75'></img></td><tr>
<tr><td><a href=ajout.php?m=1&i=$id'>Modifier l'image</a></td></tr>
<tr><td><input size='25' maxlenght='50' name='name".$id."' value=".stripslashes($array[1][1])."></td></tr>
<tr><td><input size='25' maxlenght='50' name='url".$id."' value='".$array[1][2]."'></td></tr>
<tr><td>Position :<input size='1' maxlenght='3' name='ordre".$id."' value='".$array[1][3]."'></td></tr>
<tr><td><input type='submit' value='Modifier'></td></tr></table></form>";

Pour recuperer les post je procede comme ceci :

if(!empty($_GET))
{
$url="url".$_GET['c'];
$name="name".$_GET['c'];
$ordre="ordre".$_GET['c'];
eval('$url = $_POST["'.$url.'"];'); //ici
eval('$name = $_POST["'.$name.'"];');
eval('$ordre = $_POST["'.$ordre.'"];');
if(!empty($name))
{
if(!empty($url))
{
if(!empty($ordre)|| $ordre==0)
{
$ok=requete('select count(*)as `total` from `references` where ac="1";');
$nor=mysql_fetch_object($ok);
if(($ordre <= $nor->total) && $ordre != 0)
{
$namef=str_replace(" ", " ", $name);
$namef=str_replace("'", "'", $namef);
$g=requete('select nomref, lienref, ordre from `references` where id_ref="'.$_GET['c'].'" ;');
$go=mysql_fetch_object($g);
$ref=$go->nomref;
if(strpos($go,$namef) === true)
{
$message="Pas de modification ?";
$urlf="mod.php";
$att="";
}
//echanger l'ordre


Par contre, quand je veux afficher "pas de modification", aucune fonction de comparaison ne fonctionne. Quand j'echo le type de $namef ou $name et de $go->nomref, il s'affiche string, mais impossible de les comparer.
Du coup, meme si aucune modification n'est faite, ca affiche modification reussie. Ce n'est pas vraiment genant, mais si on ne fait pas attention, on peut modifier une case sans savoir...

Si tu as une petite idee pour comparer ces deux valeurs, ca serait genial, j'ai deja presque utilisé toutes les fonctions str*.
En tout cas, merci encore!

Répondre à tkz

3

tkz, le 23 oct 2007 à 12:57:10

Ah, j'oubliais aussi, qd je defini la taille du tableau, il ne faut pas utiliser la fonction round, mais ceil comme ca:

$rows=ceil($nb/4); //nombre de lignes qui affichent 4 refs

round renvoie l'entier le plus proche, alors que ceil renverra toujours celui au dessus.

Répondre à tkz

4

 tkz, le 23 oct 2007 à 22:58:19

Resalut ! En fait, la comparaison fonctionne nickel, meme pas besoin de fonction particuliere. C'etait juste mon if/else qui etait mal construit , voila le code :

if(($ordre <= $nor->total) && $ordre != 0)
{
$namef=str_replace(" ", " ", $name);
$namef=str_replace("'", "'", $namef);
$g=requete('select nomref, lienref, ordre from `references` where id_ref="'.$_GET['c'].'" ;');
$go=mysql_fetch_object($g);
if($name!=$go->nomref || $url!=$go->lienref || $ordre!=$go->ordre) //ici
{
//echanger l'ordre
$i=requete('select ordre from `references` where id_ref="'.$_GET['c'].'";');
$id=mysql_fetch_object($i);
$ech=requete('update `references` set ordre="'.$id->ordre.'" where ordre="'.$ordre.'";');
//modifier l'enregistrement
$ech2=requete('update `references` set ordre="'.$ordre.'" where id_ref="'.$_GET['c'].'";');
$modif=requete('update `references` set nomref="'.addslashes($namef).'", lienref="'.$url.'" where id_ref="'.$_GET['c'].'";');
if($ech2)
{
$message=" Modification effectuée !";
$urlf="mod.php";
$att="";
}
}
else
{
$message="Pas de modification ?";
$urlf="mod.php";
$att="";
}
}

Voila ! Bonne soirée !!

Répondre à tkz