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 :

quand je supprime un id j'aimerai rester sur la même page


Sujet :

Langage PHP

  1. #1
    Membre du Club
    Homme Profil pro
    en étude de webmaster
    Inscrit en
    Février 2016
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : en étude de webmaster

    Informations forums :
    Inscription : Février 2016
    Messages : 125
    Points : 56
    Points
    56
    Par défaut quand je supprime un id j'aimerai rester sur la même page
    J'ai un script qui me permet de supprimer un id
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    //on fait condition qui verifie si id_suppression existe et si il est plus grand que 0
        if(TRUE === isset($_GET["id_suppression"]) && $_GET["id_suppression"] > 0 ){
            //on cree une requete sql pour supprimer l'id_plat desire
            $sql_delete = "DELETE FROM plat WHERE id_plat = '".$_GET["id_suppression"]."'";
            //je fait une condition qui verifie si la connexion c'est bien passe
            if(mysqli_errno($connexion) != 0){
                die ('ERREUR '.mysqli_error($connexion));
            }       
            //j'execute la requete
            $resultat_suppression = mysqli_query($connexion, $sql_delete);
        }
    J'ai une table avec énormément de plat, donc j'ai créer un script pour faire de la pagination.
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    //Je fait une boucle pour afficher le nombre de page qu'il y a
                                for($i = 1; $i <= $nombre_de_pages_total; $i++){
                                    //si $i est egale a page actutelle
                                    if($i == $page_actuelle){
                                        //alors on affiche la page actuelle comme ci
                                        echo '<span class="btn-floating btn-medium waves-effect waves-light green darken-1 pagination">'.$i.'</span>';
                                    }//sinon
                                    else {
                                        //on affiche les autres page comme des liens
                                        echo '<a class="btn-floating btn-medium waves-effect waves-light red pagination" href="plat_liste.php?page='.$i.'">'.$i.'</a>';
                                    }
                                }
    Mais maintenant je me rend compte que chaque fois que je supprime un id il retourne a la 1ère page alors que j'ai qu'il reste sur la même page.
    Est-ce que vous pourriez m'indiquer ce qu'il me manque svp.

  2. #2
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    pour ma part, je mets le numéro de page dans une SESSION.

    1-
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $_SESSION['liste']['numPage'] = (!empty($_GET['numPage']))? intval($_GET['numPage']) : 1;
    $page_actuelle = $_SESSION['liste']['numPage'];
    2- Et dans le lien de retour à la liste :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    <a href="................?numPage=<?php echo (!empty($_SESSION['liste']['numPage']))? intval($_SESSION['liste']['numPage']) : 1; ?>">Retour à la liste </a>
    N.B. $_SESSION['liste'] est un array.
    J'y enregistre aussi tous les critères de recherche/tri éventuel.

  3. #3
    Membre du Club
    Homme Profil pro
    en étude de webmaster
    Inscrit en
    Février 2016
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : en étude de webmaster

    Informations forums :
    Inscription : Février 2016
    Messages : 125
    Points : 56
    Points
    56
    Par défaut
    Maintenant j'arrive même plus a aller sur les autres pages, il ne veut que la première page.

    Code : 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
    //Je met dans une variable de nombre de plat a afficher
    $nbre_plat_afficher = 10;
    //Je creer une requete sql pour compter le nombre total d'id dans la table plat
    $sql_page_plat = "SELECT COUNT(id_plat) As nbr_page FROM plat";
    //Je verifie si il y a une erreur dans la requete
    if(mysqli_errno($connexion) != 0){
        die ('ERREUR '.mysqli_error($connexion));
    }
    //J'execute la requet sql
    $resultat_page_plat = mysqli_query($connexion, $sql_page_plat);
    //Je recupere le nombre plat et la met dans une variable
    $nbr_de_plat = mysqli_fetch_assoc($resultat_page_plat);
    //pour plus de faciliter a ecrire je remet le nombre de plat dans une autre variable
    $nbre_de_plat_total = $nbr_de_plat["nbr_page"];
    //Je fait une division du nombre total de plat par rapport au au nombre de plat a afficher
    $nombre_de_pages_total = ceil($nbre_de_plat_total/$nbre_plat_afficher);
     
    $_SESSION["$nbr_de_plat"]["$nombre_de_pages_total"] = (!empty($_GET["$nombre_de_pages_total"])) ? intval($_GET["$nombre_de_pages_total"]) : 1;
    $page_actuelle = $_SESSION["$nbr_de_plat"]["$nombre_de_pages_total"];
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    header("Location:plat_liste.php?page="(!empty($_SESSION["$nbr_de_plat"]["$nombre_de_pages_total"]))? intval($_SESSION["$nbr_de_plat"]["$nombre_de_pages_total"]) : 1);

  4. #4
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    Déjà, il faut comprendre ce qu'on fait : relis ce que j'ai ecrit.
    $page_actuelle n'est pas $nombre_de_pages_total !

    Tu mélanges tout......

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $_SESSION["nbr_de_plat"]["num_page_actuelle"] = (!empty($_GET["page"])) ? intval($_GET["page"]) : 1;
    $page_actuelle = $_SESSION["nbr_de_plat"]["num_page_actuelle"];
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $num_page_retour = (!empty($_SESSION["nbr_de_plat"]["num_page_actuelle"]))? intval($_SESSION["nbr_de_plat"]["num_page_actuelle"]) : 1
    header("Location: plat_liste.php?page=" . $num_page_retour);

  5. #5
    Membre du Club
    Homme Profil pro
    en étude de webmaster
    Inscrit en
    Février 2016
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : en étude de webmaster

    Informations forums :
    Inscription : Février 2016
    Messages : 125
    Points : 56
    Points
    56
    Par défaut
    C'est bon j'ai trouver pourquoi je n'arrivais pas a changer de page, par contre j'ai un problème maintenant sur la suppression.

    Fatal error: Uncaught Error: Call to undefined function Location:plat_liste.php?page=() in /home/dweber/www/base_de_donnee/plat/plat_liste.php:82 Stack trace: #0 {main} thrown in /home/dweber/www/base_de_donnee/plat/plat_liste.php on line 82
    j'ai encore des problème de code, mais je vais y arrivé, merci à toi.

  6. #6
    Membre du Club
    Homme Profil pro
    en étude de webmaster
    Inscrit en
    Février 2016
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : en étude de webmaster

    Informations forums :
    Inscription : Février 2016
    Messages : 125
    Points : 56
    Points
    56
    Par défaut
    désoler, je suis entrain de faire plein de chose en même temps et j'ai pas bien fait les choses.

  7. #7
    Membre du Club
    Homme Profil pro
    en étude de webmaster
    Inscrit en
    Février 2016
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : en étude de webmaster

    Informations forums :
    Inscription : Février 2016
    Messages : 125
    Points : 56
    Points
    56
    Par défaut
    dit moi, si "nbr_de_plat" sont des variable je dois bien mettre le $ au début et les laisser entre guillemet.
    Parce que j'ai essayé les deux version et rien ne se passe, a chaque fois il me retourne en page 1.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $_SESSION["nbr_de_plat"]["num_page_actuelle"] = (!empty($_GET["page"])) ? intval($_GET["page"]) : 1;
    $page_actuelle = $_SESSION["nbr_de_plat"]["num_page_actuelle"];
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $num_page_retour = (!empty($_SESSION["nbr_de_plat"]["num_page_actuelle"]))? intval($_SESSION["nbr_de_plat"]["num_page_actuelle"]) : 1;
    header("Location: plat_liste.php?page=" . $num_page_retour);
    ça doit être une faute bette, mais c'est celle que je vois le moins.

  8. #8
    Invité
    Invité(e)
    Par défaut
    1- Voir session_start().

    2- tes extraits de codes ne permettent pas de voir le code dans son ensemble.

  9. #9
    Membre du Club
    Homme Profil pro
    en étude de webmaster
    Inscrit en
    Février 2016
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : en étude de webmaster

    Informations forums :
    Inscription : Février 2016
    Messages : 125
    Points : 56
    Points
    56
    Par défaut
    Code : 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
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    64
    65
    66
    67
    68
    69
    70
    71
    72
    73
    74
    75
    76
    77
    78
    79
    80
    81
    82
    83
    84
    85
    86
    87
    88
    89
    90
    91
    92
    93
    94
    95
    96
    97
    98
    99
    100
    101
    102
    103
    104
    105
    106
    107
    108
    109
    110
    111
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    135
    136
    137
    138
    139
    140
    141
    142
    143
    144
    145
    146
    147
    148
    149
    150
    151
    152
    153
    154
    155
    156
    157
    158
    159
    160
    161
    162
    163
    164
    165
    166
    167
    168
    169
    170
    171
    172
    173
    174
    175
    176
    177
    178
    179
    180
    181
    182
    183
    184
    185
    186
    187
    188
    189
    190
    191
    192
    193
    194
    195
    196
    197
    198
    199
    200
    201
    202
    203
    204
    205
    206
    207
    208
    209
    210
    211
    212
    213
    214
    215
    216
    217
    218
    219
    220
    221
    222
    223
    224
    225
    226
    227
    228
    229
    230
    231
    232
    233
    234
    235
    236
    237
    238
    239
    240
    241
    242
    243
    244
    245
    246
    247
    248
    249
    250
    251
    252
    253
    254
    255
    256
    257
    258
    259
    260
    261
    262
    263
    264
    265
    266
    267
    268
    269
    270
    271
    272
    273
    274
    275
    276
    277
    278
    279
    280
    281
    282
    283
    284
    285
    286
    287
    288
    289
    290
    291
    292
    293
    294
    295
    296
    297
    298
    <?php
    include '../../connexion_bd/connexion_bd.php';
    $nav_en_cours = "Plat";
    /*---------------------------------------------------------------------------*/
    session_start();
    if(empty($_SESSION["user_connecter"]) || $_SESSION["user_connecter"] !== TRUE){    
        header("Location:../../zadmin.php");
        exit();    
    }
    /*--------------------------------------------------------------------------*/
    //Je met dans une variable de nombre de plat a afficher
    $nbre_plat_afficher = 10;
    //Je creer une requete sql pour compter le nombre total d'id dans la table plat
    $sql_page_plat = "SELECT COUNT(id_plat) As nbr_page FROM plat";
    //Je verifie si il y a une erreur dans la requete
    if(mysqli_errno($connexion) != 0){
        die ('ERREUR '.mysqli_error($connexion));
    }
    //J'execute la requet sql
    $resultat_page_plat = mysqli_query($connexion, $sql_page_plat);
    //Je recupere le nombre plat et la met dans une variable
    $nbr_de_plat = mysqli_fetch_assoc($resultat_page_plat);
    //pour plus de faciliter a ecrire je remet le nombre de plat dans une autre variable
    $nbre_de_plat_total = $nbr_de_plat["nbr_page"];
    //Je fait une division du nombre total de plat par rapport au au nombre de plat a afficher
    $nombre_de_pages_total = ceil($nbre_de_plat_total/$nbre_plat_afficher);
     
    //
    $_SESSION["nbr_de_plat"]["num_page_actuelle"] = (!empty($_GET["page"])) ? intval($_GET["page"]) : 1;
    $page_actuelle = $_SESSION["nbr_de_plat"]["num_page_actuelle"];
     
    //Je fait un calcul ou je multiplie la page actuelle au nombre de plat a afficher moins le nombre de plat a afficher
    $premiere_page = $page_actuelle * $nbre_plat_afficher - $nbre_plat_afficher;
    //Je creer une requete sql qui me recupere tout de la table plat trier par genre et ensuite descriptif avec une limit qui m'affiche
    //a partir du 0 jusqu'au 10 et ainsi de suite de 10 en 10
    $sql_par_page = "SELECT * FROM plat JOIN genre_des_plats ON plat.ref_genre_des_plats = genre_des_plats.id_genre_des_plats ORDER BY id_genre_des_plats, descriptif LIMIT ".$premiere_page.", ".$nbre_plat_afficher."";
    //Je verifie si il y a une erreur dans la requete
    if(mysqli_errno($connexion) != 0){
        die ('ERREUR '.mysqli_error($connexion));
    }
    //J'execute la requete sql
    $resultat_par_page = mysqli_query($connexion, $sql_par_page);
     
    /*--------------------------------------------------------------------------*/
    //je cree une requete sql pour selectionner tout de la table
    $sql_select_insert_genre = "SELECT * FROM genre_des_plats ORDER BY id_genre_des_plats";
    //je fait une condition qui verifie si la connexion c'est bien passe
    if(mysqli_errno($connexion) != 0){
        die ('ERREUR '.mysqli_error($connexion));
    }
    //j'execute ma requete sql
    $resultat_selec_insert_genre = mysqli_query($connexion, $sql_select_insert_genre);
    /*---------------------------------------------------------------------------*/
    //on fait condition qui verifie ce qui est envoye dans le GET
    if($_SERVER['REQUEST_METHOD'] == 'GET'){
        // variable booleene qui indiquera si on affiche ou pas le formulaire
        $affiche_formulaire = true;
        // variable vide qui affichera les messages d'erreur
        $message = "";    
        /*--------------------------------------------*/
        //on fait condition qui verifie si id_suppression existe et si il est plus grand que 0
        if(TRUE === isset($_GET["id_suppression"]) && $_GET["id_suppression"] > 0 ){
            //on cree une requete sql pour supprimer l'id_plat desire
            $sql_delete = "DELETE FROM plat WHERE id_plat = '".$_GET["id_suppression"]."'";
            //je fait une condition qui verifie si la connexion c'est bien passe
            if(mysqli_errno($connexion) != 0){
                die ('ERREUR '.mysqli_error($connexion));
            }       
            //j'execute la requete
            $resultat_suppression = mysqli_query($connexion, $sql_delete);
            //on fait retourne sur la page voulus
     
    	$num_page_retour = (!empty($_SESSION["nbr_de_plat"]["num_page_actuelle"]))? intval($_SESSION["nbr_de_plat"]["num_page_actuelle"]) : 1;
            header("Location: plat_liste.php?page=" . $num_page_retour);
            //on sort
            exit();
        }   
    }
    //sinon on envoie dans le POST
    else if ($_SERVER['REQUEST_METHOD'] == 'POST') {
        // tableau qui contiendra le récap de tout ce que la personne a posté
        $message_recapitulatif = array();
        // chaque erreur sera stocké comme élément de ce tableau :
        $message_erreur = array();
        /*--------------------------------------------*/
        //est-ce que $_POST["prixentree"] existe
        if (FALSE === isset($_POST["prixentree"])){
            //sinon message d'erreur
            $message_erreur[] = "Pas de prix entrée reçu";    
        }//est-ce que $_POST["prixentree"] est vide
        else if (0 == strlen($_POST["prixentree"])) {
            $message_erreur[] = "Vous avez rien noter dans prix entrée";    
        }//est-ce que $_POST["prixentree"] est un nombre
        else if (is_numeric($_POST["prixentree"]) == false) {
            $message_erreur[] = "Vous devez noter un nombre dans prix entrée";   
        }//est-ce que $_POST["prixentree"] et plus grand que 0
        else if (-1 >= $_POST["prixentree"]) {
            $message_erreur[] = "Prix entrée n'est pas positif";
        }
                /*======================*/   
            //est-ce que $_POST["prixplat"] existe
        if (FALSE === isset($_POST["prixplat"])){
            //sinon message d'erreur
            $message_erreur[] = "Pas de prix plat reçu";    
        }//est-ce que $_POST["prixplat"] est vide
        else if (0 == strlen($_POST["prixplat"])) {
            $message_erreur[] = "Vous avez rien noter dans prix plat";    
        }//est-ce que $_POST["prixplat"] est un nombre
        else if (is_numeric($_POST["prixplat"]) == false) {
            $message_erreur[] = "Vous devez noter un nombre dans prix plat";    
        }//est-ce que $_POST["prixplat"] et plus grand que 0
        else if (-1 >= $_POST["prixplat"]) {
            $message_erreur[] = "Prix plat n'est pas positif";
        }    
                    /*======================*/   
            //est-ce que $_POST["prixaperitif"] existe
        if (FALSE === isset($_POST["prixaperitif"])){
            //sinon message d'erreur
            $message_erreur[] = "Pas de prix apéritif reçu";    
        }//est-ce que $_POST["prixaperitif"] est vide
        else if (0 == strlen($_POST["prixaperitif"])) {
            $message_erreur[] = "Vous avez rien noter dans prix apéritif";    
        }//est-ce que $_POST["prixaperitif"] est un nombre
        else if (is_numeric($_POST["prixaperitif"]) == false) {
            $message_erreur[] = "Vous devez noter un nombre dans prix apéritif";    
        }//est-ce que $_POST["prixaperitif"] et plus grand que 0
        else if (-1 >= $_POST["prixaperitif"]) {
            $message_erreur[] = "Prix apéritif n'est pas positif";
        }
                /*======================*/   
        //est-ce que $_POST["descriptif"] existe
        if (FALSE === isset($_POST["descriptif"])){
            $message_erreur[] = "Pas de descriptif reçu";   
        }//est-ce que $_POST["descriptif"] a trois caractere
        else if (3 > strlen($_POST["descriptif"])) {
            $message_erreur[] = 'Descriptif trop court, mini 3 caractere';
        }    
                /*======================*/
        //on vérifie si $message_erreur est vide
        if(empty($message_erreur)){
            //on met dans une variable chaque valeur du formulaire
            $prixentree = trim($_POST["prixentree"]);
            $prixplat = trim($_POST["prixplat"]);
            $prixaperitif = trim($_POST["prixaperitif"]);
            $descriptif = trim($_POST["descriptif"]);
            $genre = $_POST["genre"];
            // insert et utiliser mysqli_real_escape_string
            //j'ai pas mis le mysqli_real_escape_string car il fait planté le code
            $sql_insert = "INSERT INTO plat (id_plat, prix_entree, prix_plat, prix_aperitif, descriptif, ref_genre_des_plats) VALUES (NULL, '".$prixentree."', '".$prixplat."', '".$prixaperitif."', '".$descriptif."', '".$genre."')";
            //je fait une condition qui verifie si la connexion c'est bien passe
            if(mysqli_errno($connexion) != 0){
                die ('ERREUR '.mysqli_error($connexion));
            }       
            //j'execute la requete
            $resultat_insert = mysqli_query($connexion, $sql_insert);
            // le formulaire ne sera pas réaffiché
            $affiche_formulaire = TRUE;
        }
        // sinon
        else {
            // on fabrique un message d'erreur
            $message = implode(", ", $message_erreur);
            // on reaffiche le formulaire
            $affiche_formulaire = true;
        }
    }
    /*--------------------------------------------------------------------------*/
    //on ferme la connexion à la base de donnee
    $ok = mysqli_close($connexion);
    ?>
    <?php include '../../doctype/doctype_header_admin.php'; ?>
        <section class="margeadmin">
            <article>
                <!-- C'est a ce niveau que j'affiche si il y a un message d'erreur -->
                <?php echo $message; ?>
                <!-- Si $affiche_formulaire bien envoyé dans le get alors j'affiche le formulaire -->
                <?php if($affiche_formulaire){ ?>
                        <form action="plat_liste.php" method="post">
                            <p class="centrer">Veuillez bien remplir chaque case</p>
                            <div class="row">
                                <div class="input-field col s12 m2 l2">
                                    <input id="insert" name="prixentree" type="text" class="validate" value="0"/>
                                    <label for="insert" class="grey-text text-darken-4">Insérer prix entrée</label>
                                </div>
                                <div class="input-field col s12 m2 l2">
                                    <input id="insert1" name="prixplat" type="text" class="validate" value="0"/>
                                    <label for="insert1" class="grey-text text-darken-4">Insérer prix plat</label>
                                </div>
                                <div class="input-field col s12 m2 l2">
                                    <input id="insert2" name="prixaperitif" type="text" class="validate" value="0"/>
                                    <label for="insert2" class="grey-text text-darken-4">Insérer prix apéritif</label>
                                </div>
                                <div class="input-field col s12 m3 l3">
                                    <input id="insert3" name="descriptif" type="text" class="validate"/>
                                    <label for="insert3" class="grey-text text-darken-4">Insérer descriptif</label>
                                </div>
                                <div class="input-field col s12 m2 l2">
                                    <select class="SelrefPlat" name="genre">
                                    <!-- Je fais une boucle sur $resultat_select_insert_sugg pour afficher tant qu'il y a quelque chose dedans -->
                                    <?php while ($select_genre = mysqli_fetch_assoc($resultat_selec_insert_genre)){?>
     
                                    <option value="<?php echo $select_genre["id_genre_des_plats"] ?>"><?php echo $select_genre["nom_des_genres"]; ?></option>
     
                                    <?php } ?>
                                    </select>
                                </div>
                            </div>
                            <div class="row">
                                <div class="col s12 m12 l12">
                                    <button class="boutonvert btn waves-effect waves-light" type="submit" name="action">Insérer</button>
                                </div>
                            </div>
                        </form>
                <?php } ?>
                <div class="row">
                    <div class="col s12 m12 l12">
                        <h5 class="souligne">Table Plat</h5>
                    </div>
                </div>
                <div class="row">
                    <div class="col s12 m4 l4">
                        Descriptif
                    </div>
                    <div class="col s12 m1 l1">
                        Entrée
                    </div>
                    <div class="col s12 m1 l1">
                        Plat
                    </div>
                    <div class="col s12 m1 l1">
                        Apéritif
                    </div>
                    <div class="col s12 m2 l2">
                        Genre
                    </div>
                    <div class="col s12 m3 l3">
                        Action
                    </div>
                </div>
                    <!-- Je fais une boucle sur $resultat_select pour afficher tant qu'il y a quelque chose dedans -->
                    <?php while($plat_select = mysqli_fetch_assoc($resultat_par_page)){ ?>
                        <div class="row">
                            <div class="col s12 m4 l4">
                                <?php echo $plat_select["titre_desc"] ?> <?php echo $plat_select["descriptif"]; ?>
                            </div>
                            <div class="col s12 m1 l1">
                                <?php if($plat_select["prix_entree"] == 0){
                                    echo " ";
                                } else {
                                    echo $plat_select["prix_entree"];
                                }?>
                            </div>
                            <div class="col s12 m1 l1">
                                <?php if($plat_select["prix_plat"] == 0){
                                    echo " ";
                                } else {
                                    echo $plat_select["prix_plat"];
                                }?>
                            </div>
                            <div class="col s12 m1 l1">
                                <?php if($plat_select["prix_aperitif"] == 0){
                                    echo " ";
                                } else {
                                    echo $plat_select["prix_aperitif"];
                                }?>
                            </div>
                            <div class="col s12 m2 l2">
                                <?php echo $plat_select["nom_des_genres"]; ?>
                            </div>
                            <div class="col s12 m3 l3">
                                <a class="boutonvert btn waves-effect waves-light ajoumodsup" href="modif_plat_liste.php?modif_plat=<?php echo $plat_select["id_plat"]; ?>">Modifier</a>
                                <a class="boutonvert btn waves-effect waves-light ajoumodsup" href="plat_liste.php?id_suppression=<?php echo $plat_select["id_plat"]; ?>">Supprimer</a>
                            </div>
                        </div>
                    <?php } ?>
                <div class="row">
                    <div class="col s12 m12 l12">
                        <p class="centrer">
                            <?php
                                //Je fait une boucle pour afficher le nombre de page qu'il y a
                                for($i = 1; $i <= $nombre_de_pages_total; $i++){
                                    //si $i est egale a page actutelle
                                    if($i == $page_actuelle){
                                        //alors on affiche la page actuelle comme ci
                                        echo '<span class="btn-floating btn-medium waves-effect waves-light green darken-1 pagination">'.$i.'</span>';
                                    }//sinon
                                    else {
                                        //on affiche les autres page comme des liens
                                        echo '<a class="btn-floating btn-medium waves-effect waves-light red pagination" href="plat_liste.php?page='.$i.'">'.$i.'</a>';
                                    }
                                } 
                            ?> 
                        </p>
                    </div>
                </div>
            </article>
        </section>
    <?php include '../../doctype/doctype_footer_admin.php'; ?>

  10. #10
    Invité
    Invité(e)
    Par défaut
    Quel était le code AVANT toute modification ?

    Ce qui m'intéresse, c'est :
    • comment était défini $page_actuelle ?

  11. #11
    Membre du Club
    Homme Profil pro
    en étude de webmaster
    Inscrit en
    Février 2016
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : en étude de webmaster

    Informations forums :
    Inscription : Février 2016
    Messages : 125
    Points : 56
    Points
    56
    Par défaut
    tout est dedans, la seul chose que j'ai supprimé c'était une condition et vérification du $_GET, vus que j'en ai pas besoin.

  12. #12
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    AVANT d'écrire (lignes 29-30 de ton code) :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $_SESSION["nbr_de_plat"]["num_page_actuelle"] = (!empty($_GET["page"])) ? intval($_GET["page"]) : 1;
    $page_actuelle = $_SESSION["nbr_de_plat"]["num_page_actuelle"];
    $page_actuelle devait bien être défini autrement.
    Comment ?

  13. #13
    Membre du Club
    Homme Profil pro
    en étude de webmaster
    Inscrit en
    Février 2016
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : en étude de webmaster

    Informations forums :
    Inscription : Février 2016
    Messages : 125
    Points : 56
    Points
    56
    Par défaut
    Je te redis ça demain, parce qu'au bureau je n'ai plus accès a l'ancienne version, mais j'en ai une copie sur mon ordi à la maison.

  14. #14
    Membre du Club
    Homme Profil pro
    en étude de webmaster
    Inscrit en
    Février 2016
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : en étude de webmaster

    Informations forums :
    Inscription : Février 2016
    Messages : 125
    Points : 56
    Points
    56
    Par défaut
    Salut,
    Excuse du temps de réponse, j'ai eu du boulot entre temps.
    voilà le code avant modification:

    Code : 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
    39
    40
    41
    42
    43
    44
    45
    46
    47
    //Je met dans une variable de nombre de plat a afficher
    $nbre_plat_afficher = 10;
     
    //Je creer une requete sql pour compter le nombre total d'id dans la table plat
    $sql_page_plat = "SELECT COUNT(id_plat) As nbr_page FROM plat";
    //Je verifie si il y a une erreur dans la requete
    if(mysqli_errno($connexion) != 0){
        die ('ERREUR '.mysqli_error($connexion));
    }
    //J'execute la requet sql
    $resultat_page_plat = mysqli_query($connexion, $sql_page_plat);
     
    //Je recupere le nombre plat et la met dans une variable
    $nbr_de_plat = mysqli_fetch_assoc($resultat_page_plat);
    //pour plus de faciliter a ecrire je remet le nombre de plat dans une autre variable
    $nbre_de_plat_total = $nbr_de_plat["nbr_page"];
    //Je fait une division du nombre total de plat par rapport au au nombre de plat a afficher
    $nombre_de_pages_total = ceil($nbre_de_plat_total/$nbre_plat_afficher);
     
    //J'envoie la nombre de la page dans le GET en verifiant si c'est un nombre si il est plus grand que 0 et si il est plus petit
    //ou egal au nombre de page total
    if(!empty($_GET["page"]) && is_numeric($_GET["page"]) && $_GET["page"] > 0 && $_GET["page"] <= $nombre_de_pages_total){
     
        //je place le get dans une variable en verifiant en meme temps que c'est un entier
        $page_actuelle = intval($_GET["page"]);
     
    }//sinon
    else{
     
        //je dit que la page actuelle est la numero 1
        $page_actuelle = 1;
     
    }
     
    //Je fait un calcul ou je multiplie la page actuelle au nombre de plat a afficher moins le nombre de plat a afficher
    $premiere_page = $page_actuelle * $nbre_plat_afficher - $nbre_plat_afficher;
     
    //Je creer une requete sql qui me recupere tout de la table plat trier par genre et ensuite descriptif avec une limit qui m'affiche
    //a partir du 0 jusqu'au 10 et ainsi de suite de 10 en 10
    $sql_par_page = "SELECT * FROM plat JOIN genre_des_plats ON plat.ref_genre_des_plats = genre_des_plats.id_genre_des_plats ORDER BY id_genre_des_plats, descriptif LIMIT ".$premiere_page.", ".$nbre_plat_afficher."";
    //Je verifie si il y a une erreur dans la requete
    if(mysqli_errno($connexion) != 0){
        die ('ERREUR '.mysqli_error($connexion));
    }
     
    //J'execute la requete sql
    $resultat_par_page = mysqli_query($connexion, $sql_par_page);
    et plus précisément le moment de la création de la variable $page_actuelle:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    //J'envoie la nombre de la page dans le GET en verifiant si c'est un nombre si il est plus grand que 0 et si il est plus petit
    //ou egal au nombre de page total
    if(!empty($_GET["page"]) && is_numeric($_GET["page"]) && $_GET["page"] > 0 && $_GET["page"] <= $nombre_de_pages_total){
     
        //je place le get dans une variable en verifiant en meme temps que c'est un entier
        $page_actuelle = intval($_GET["page"]);
     
    }//sinon
    else{
     
        //je dit que la page actuelle est la numero 1
        $page_actuelle = 1;
     
    }

  15. #15
    Invité
    Invité(e)
    Par défaut
    Bonjour,

    c'est justement TOUTE cette partie là qu'il faut remplacer par :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    $_SESSION["nbr_de_plat"]["num_page_actuelle"] = (!empty($_GET["page"])) ? intval($_GET["page"]) : 1;
    $page_actuelle = $_SESSION["nbr_de_plat"]["num_page_actuelle"];
    On peut "améliorer" :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    $_SESSION["nbr_de_plat"]["num_page_actuelle"] = (!empty($_GET["page"])) ? min( intval($_GET["page"]), $nombre_de_pages_total ) : 1;
    if( empty($_SESSION["nbr_de_plat"]["num_page_actuelle"]) ){ $_SESSION["nbr_de_plat"]["num_page_actuelle"] = 1;  }
    $page_actuelle = $_SESSION["nbr_de_plat"]["num_page_actuelle"];
    Dernière modification par Invité ; 17/07/2018 à 10h21.

  16. #16
    Membre du Club
    Homme Profil pro
    en étude de webmaster
    Inscrit en
    Février 2016
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : en étude de webmaster

    Informations forums :
    Inscription : Février 2016
    Messages : 125
    Points : 56
    Points
    56
    Par défaut
    ça me dit qu'il y a une erreur sur cette ligne
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    if(!empty($_SESSION["nbr_de_plat"]["num_page_actuelle"] = ) ){ $_SESSION["nbr_de_plat"]["num_page_actuelle"] = 1; }
    C'est après le premier = il manque quelque chose est-ce que ça serai 1

  17. #17
    Invité
    Invité(e)
    Par défaut
    Erreur de frappe.
    Il faut enlever le =.

  18. #18
    Membre du Club
    Homme Profil pro
    en étude de webmaster
    Inscrit en
    Février 2016
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : en étude de webmaster

    Informations forums :
    Inscription : Février 2016
    Messages : 125
    Points : 56
    Points
    56
    Par défaut
    ok

  19. #19
    Membre du Club
    Homme Profil pro
    en étude de webmaster
    Inscrit en
    Février 2016
    Messages
    125
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : Suisse

    Informations professionnelles :
    Activité : en étude de webmaster

    Informations forums :
    Inscription : Février 2016
    Messages : 125
    Points : 56
    Points
    56
    Par défaut
    dans
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    $_SESSION["nbr_de_plat"]["num_page_actuelle"] = 1
    ça me bloque sur la première page, si j'enlève le = 1 je peux aller sur les autres pages.
    Par contre quand j'ajoute un plat, ça me retourne toujours sur la première page. J'arrive pas a comprendre qu'est-ce qui indique la page sur laquelle je suis.

  20. #20
    Invité
    Invité(e)
    Par défaut
    Si tu sors un bout de code de son contexte, je ne peux rien répondre.
    Montre ton code.

    J'arrive pas a comprendre qu'est-ce qui indique la page sur laquelle je suis
    ??? Les noms des variables sont pourtant clairs, non ???

+ Répondre à la discussion
Cette discussion est résolue.
Page 1 sur 2 12 DernièreDernière

Discussions similaires

  1. [XL-2010] Message d’erreur quand je supprime le texte d’un comboBox sous la fonction VLookup
    Par a.ouguerzam dans le forum Macros et VBA Excel
    Réponses: 18
    Dernier message: 14/11/2014, 10h34
  2. [XL-2003] Lancer une macro quand on supprime une ligne
    Par nicoaix dans le forum Macros et VBA Excel
    Réponses: 1
    Dernier message: 02/12/2013, 16h08
  3. [Mapping] Cascade : supprimer les enfants quand on supprime le parent
    Par gargantua dans le forum Hibernate
    Réponses: 2
    Dernier message: 25/09/2013, 15h47
  4. Réponses: 6
    Dernier message: 23/06/2009, 09h53
  5. Réponses: 4
    Dernier message: 28/05/2008, 14h56

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