IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Langage PHP Discussion :

formulaire avec des checkbox pour effacer certains enregistrements


Sujet :

Langage PHP

  1. #1
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 828
    Points
    5 828
    Billets dans le blog
    1
    Par défaut formulaire avec des checkbox pour effacer certains enregistrements
    Bonjour,

    je dispose d'un tableau $data contenant des données issues d'une bdd et je souhaite donner la possibilité à l'utilisateur de sélectionner certaines lignes pour les supprimer.

    Voici mon code :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
      <form action="" method="post">
            <table>
            <?php
            foreach ($data as $record) {
                echo "<tr><td>";
                echo $record['date_actus'];
                echo "</td><td>";
                echo $record['texte_actus'];
                echo "</td><td>";
                echo '<input type="checkbox" name="actus[]">';
                echo "</td></tr>";
            }
            ?>
            <table>
            <input type="submit" value="effacer" name="submitdelete">
        </form>
        <?php
        if (isset($_POST['submitdelete']) ) {var_dump($_POST);}
        ?>
    .
    Visiblement, je n'ai pas ajouté correctement les checkbox vu que le var_dump ligne 18 ne contient qu'un seul élément, celui de name submitdelete. Merci de me dire comment il faudrait faire.

  2. #2
    Expert éminent sénior
    Avatar de ProgElecT
    Homme Profil pro
    Retraité
    Inscrit en
    Décembre 2004
    Messages
    6 095
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 68
    Localisation : France, Haute Savoie (Rhône Alpes)

    Informations professionnelles :
    Activité : Retraité
    Secteur : Communication - Médias

    Informations forums :
    Inscription : Décembre 2004
    Messages : 6 095
    Points : 16 606
    Points
    16 606
    Par défaut
    Salut

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
            foreach ($data as $record) {
                echo "<tr><td>";
                echo $record['date_actus'];
                echo "</td><td>";
                echo $record['texte_actus'];
                echo "</td><td>";
                echo '<input type="checkbox" name="actus[]">';
                echo "</td></tr>";
            }
    Ne serai se pas plutôt
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
            foreach ($data as $record) {
                echo "<tr><td>";
                echo $data['date_actus']; // <====
                echo "</td><td>";
                echo $data['texte_actus']; // <====
                echo "</td><td>";
                echo '<input type="checkbox" name="actus[]">';
                echo "</td></tr>";
            }

  3. #3
    Expert éminent
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 201
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 201
    Points : 8 426
    Points
    8 426
    Billets dans le blog
    17
    Par défaut
    En supposant que chaque enregistrement ait un identifiant id tu peux faire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <input type="checkbox" name="delete[]" value="<?= $record['id'] ?>">
    Ainsi $_POST['delete'] sera un tableau d'ID de ligne à supprimer.

  4. #4
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 828
    Points
    5 828
    Billets dans le blog
    1
    Par défaut
    Tous comptes faits, mon code est correct. Mais un autre problème fera peut-être l'objet d'une autre discussion.

  5. #5
    Expert éminent
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 201
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 201
    Points : 8 426
    Points
    8 426
    Billets dans le blog
    17
    Par défaut
    Citation Envoyé par laurentSc Voir le message
    Tous comptes faits, mon code est correct. Mais un autre problème fera peut-être l'objet d'une autre discussion.
    Ouais, genre identifier les lignes à supprimer en base

  6. #6
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 828
    Points
    5 828
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par Séb. Voir le message
    Ouais, genre identifier les lignes à supprimer en base
    Exactement (mon formulaire aide à deviner), mais je m'y replonge pas ce soir ; on verra demain.

  7. #7
    Expert éminent
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 201
    Détails du profil
    Informations personnelles :
    Âge : 46
    Localisation : France

    Informations professionnelles :
    Secteur : High Tech - Opérateur de télécommunications

    Informations forums :
    Inscription : Mars 2005
    Messages : 5 201
    Points : 8 426
    Points
    8 426
    Billets dans le blog
    17
    Par défaut
    Citation Envoyé par laurentSc Voir le message
    Exactement (mon formulaire aide à deviner), mais je m'y replonge pas ce soir ; on verra demain.
    Dans ce cas il suffira de (re)lire ma réponse un peu plus haut

    https://www.developpez.net/forums/d2.../#post11956972

  8. #8
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 828
    Points
    5 828
    Billets dans le blog
    1
    Par défaut
    J'ai utilisé ton conseil :
    Code php : Sélectionner tout - Visualiser dans une fenêtre à part
    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
        <?php
        $pps = new PDOPlusPlus();
        $sql = <<<sql
              SELECT texte_actus,date_actus,id_actus FROM arnaud.t_actus ORDER BY date_actus;
              sql;
        $data = $pps->select($sql);
        ?>
        <form action="" method="post">
          <table>
            <tr><th>date</th><th>texte</th><th>effacer</th></tr>
            <?php
            $i=0;
            foreach ($data as $record) {?>
                <tr><td>
                <?= $record['date_actus'];?>
                </td><td>
                <?= $record['texte_actus'];?>
                </td><td>
                <input type="checkbox" name="delete[]" value="<?=$record['id_actus']?>">
                </td></tr>
            <?php
            }
            ?>
          </table>
          <input type="submit" value="effacer" name="submitdelete">
        </form>
        <?php
        if (isset($_POST['submitdelete']) ) {
            $ppd = new PDOPlusPlus();
            foreach ($_POST['delete'] as $one_actus) {
                    $sql = <<<sql
                DELETE FROM arnaud.t_actus where id_actus={$one_actus};
                sql;
     
                $data = $ppd->execute($sql);
            }
        }
        ?>
    Donc l'action du formulaire est sur la même page que celui-ci. Donc après avoir exécuté l'effacement en base, le formulaire est réaffiché. Le souci est que la ou les enregistrement(s) qu'on vient d'effacer sont encore présents. Comment éviter cela ?

  9. #9
    Membre expert
    Avatar de cavo789
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2004
    Messages
    1 785
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 785
    Points : 3 048
    Points
    3 048
    Par défaut
    Après la suppression tu recharges la page...

  10. #10
    Membre chevronné
    Profil pro
    Inscrit en
    Mai 2006
    Messages
    721
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2006
    Messages : 721
    Points : 1 877
    Points
    1 877
    Par défaut
    Il suffit de remonter le bout de code qui fait le delete...
    Tout le code qui gère le résultat d'une requête POST devrait aller au dessus, avant même le HTML.

  11. #11
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 828
    Points
    5 828
    Billets dans le blog
    1
    Par défaut
    Merci à vous 2 de m'avoir répondu mais la réponse de binarygirl est plus intéressante...

  12. #12
    Expert confirmé
    Avatar de laurentSc
    Homme Profil pro
    Webmaster débutant perpétuel !
    Inscrit en
    Octobre 2006
    Messages
    10 470
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 60
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Webmaster débutant perpétuel !
    Secteur : Industrie

    Informations forums :
    Inscription : Octobre 2006
    Messages : 10 470
    Points : 5 828
    Points
    5 828
    Billets dans le blog
    1
    Par défaut
    Citation Envoyé par laurentSc Voir le message
    mais la réponse de binarygirl est plus intéressante...
    Petite explication pour cette préférence : cette façon de faire, ça m'a rappelé que je l'avais déjà vue et noté que c'était une bonne pratique (j'avais oublié).

  13. #13
    Membre expert
    Avatar de cavo789
    Homme Profil pro
    Développeur Web
    Inscrit en
    Mai 2004
    Messages
    1 785
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Belgique

    Informations professionnelles :
    Activité : Développeur Web

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 785
    Points : 3 048
    Points
    3 048
    Par défaut
    Citation Envoyé par laurentSc Voir le message
    Petite explication pour cette préférence : cette façon de faire, ça m'a rappelé que je l'avais déjà vue et noté que c'était une bonne pratique (j'avais oublié).
    Pas de souci, aucune vexation ;-)

    J'ai répondu rapido parce qu'on pouvait aussi imaginer que ton DELETE était fait en Ajax et que, oui, derrière il faut alors recharger la page.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [AC-2016] Formulaire avec liste déroulante pour sélection des enregistrements
    Par sadozias dans le forum Access
    Réponses: 2
    Dernier message: 22/02/2023, 13h17
  2. Réponses: 1
    Dernier message: 25/04/2016, 20h42
  3. Controle d'un formulaire avec des checkboxs
    Par sushi_ dans le forum Général JavaScript
    Réponses: 4
    Dernier message: 06/06/2007, 10h48
  4. Réponses: 2
    Dernier message: 08/05/2006, 21h08
  5. Réponses: 6
    Dernier message: 23/05/2005, 15h38

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo