|
Publicité ' | |||||||||||||||||||||||
|
|
#1 | ||
|
Invité de passage
![]() Cédric Étudiant Inscription : janvier 2012 Messages : 1 ![]() |
Bonjour,
Je suis débutant en PHP/MySQL et dois rendre un projet. Celui-ci consiste à mettre en place un glossaire bilingue constitué de termes avec leur traduction, définition et contexte dans les deux langues. L'interface doit permettre aux utilisateurs de rechercher un terme et d'ajouter une traduction ou une définition. J'ai donc :
J'ai une page qui affiche le contenu de la table "temporaire" dans un formulaire, avec un bouton "Ajouter" en-dessous. Lorsque je clique sur ce bouton, un enregistrement se crée bien dans la table "ajouts", mais tous les champs sont vides. Voici le code : Code :
Merci d'avance. |
||
|
|
00
|
|
|
#2 | ||
|
Membre confirmé
![]() ![]() Clément Développeur informatique Inscription : décembre 2006 Messages : 213 ![]() |
Salut dicdic
Plusieurs choses qui ne collent pas (sans parler "d'optimalité", juste que ton code soit correct). - Tu as une balise <form> que tu ouvres, mais que tu ne fermes jamais. (après le if ($res)). - Tu places des balises <form> à l'intérieur d'une autre balise <form>, ce qui est rudement déconseillé, voire peut être même tout à fait incorrect et sujet à des comportements indéterminés. - Le formulaire que tu envoies lorsque tu cliques sur "Ajouter" ne contient PAS les données que tu crois. En effet, les données de la balise input "radio1" sont dans un autre formulaire, celui du dessus, et donc les données que tu soumets quand tu cliques sur ajouter ne sont pas celles du bon formulaire. Tu récupères donc des valeurs vides, d'où les valeurs vides insérées. Pour corriger ton problème, tu dois donc : Arreter d'imbriquer des formulaires les uns dans les autres, et placer les input que tu veux à l'intérieur du bon formulaire. En gros, réfléchis bien aux valeurs qui sont envoyés (via HTTP Post) à ton script lorsque tu cliques sur "Ajouter", tu devrais comprendre. D'ailleurs, avec ta technique des boutons radio, pourquoi avoir plusieurs fois un bouton ajouter ? Un seul suffirait. Mais il serait sage de faire attention au point suivant: On évite en général de mettre plusieurs valeurs côte à côte dans un input, séparées par un caractères spécial (ici, un '|'). Que se passera-t-il si une des valeurs contient déjà un '|' ? N'as tu pas un champ entier "identifiant" dans ta table ? Il te suffirait alors de passer cet identifiant comme valeur, et tu pourrais facilement insérer les bonnes valeurs. Code :
|
||
|
|
00
|
Copyright © 2000-2012 - www.developpez.com