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

C# Discussion :

Créer un système de pagination


Sujet :

C#

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre très actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2011
    Messages
    255
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2011
    Messages : 255
    Par défaut Créer un système de pagination
    Bonjours à tous,

    Ayant quelque centaine de ligne a affiché, je me suis dit que la pagination était la meilleur solutions ( cela reduira la temps de chargement de la page qui chargera par exemple 10 lignes par pages, et surtout un conforme pour l'utilisateur).

    Mais je ne sais pas du tout comment m'y prendre.

    Voici ma fonction qui liste mes données issue d'SQL server :

    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
     
     public static List<BConseil> ListerConseil(string conditionColonne, string valueCondition, string OrderBY)
            {
                string requete = "";
                if (!string.IsNullOrEmpty(valueCondition))
                {
                    requete = "SELECT * FROM conseil WHERE " + conditionColonne + " = " + valueCondition + " ORDER BY " + OrderBY + " DESC ";
                }
                else
                {
                    requete = "SELECT * FROM conseil ORDER BY " + OrderBY + " DESC ";
                }
                List<BConseil> listConseil = new List<BConseil>();
                using (SqlConnection cx = new SqlConnection(ConnectionString))
                {
                    cx.Open();
                    SqlCommand cmd = new SqlCommand(requete, cx);
                    cmd.Connection = cx;
                    SqlDataReader dReader;
                    dReader = cmd.ExecuteReader();
     
                    int idConseil;
                    string text;
                    DateTime dateAjout;
                    string img;
                    int idSecteur;
                    string titre;
                    int idCat;
                    string imageGrande;
     
                    while (dReader.Read())
                    {
                        idConseil = dReader.GetInt32(0);
                        text = dReader.GetString(1);
                        dateAjout = dReader.GetDateTime(2);
                        img = dReader.GetString(3);
                        idSecteur = dReader.GetInt32(4);
                        titre = dReader.GetString(5);
                        idCat = dReader.GetInt32(6);
                        imageGrande = dReader.GetString(7);
     
                        BConseil newConseil = new BConseil(idConseil, text, dateAjout, img, idSecteur, titre, idCat,imageGrande);
                        listConseil.Add(newConseil);
                    }
                    cx.Close();
                    dReader.Close();
                    return listConseil;
                }
            }
    Ensuite je me sert de cette fonction pour créer une fonction "de mise en forme " :

    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
     
     public static string MiseEnFormConseil(string idCat)
            {
            string result = "";
     
            foreach (var item in DBConseil.ListerConseil("idCat",idCat.ToString(),"DateAjout"))
            {
                if (item.idCat == 5)
                {
                    continue;
                }
                result += "<div class=templatemo_box>";
                result += " <h2>";
                result += " <span></span>" + item.titre + "</h2>";
                result += "<div class=body>"
                        + "         <a href=ficheActu.aspx?actu=" + item.id + "><img class=news_image alt=\"" + item.titre + "\" src=Ressources/conseilJour/" + item.image + "></a>"
                        + "         Publié le " + string.Format("{0: dd MMMM yyyy}", item.dateAjout)
                        + "         <div id=textConseil>"
                        + ToolKit.coupePhrase(item.text, 180)
                        + "         </div>"
                        + "         <div id=lienFicheConseil>"
                        + "             <a class=bt href=ficheConseil.aspx?conseil=" + item.id + ">Consulter la fiche de l'actualité</a>"
                        + "         </div>"
                        + "     </div>";
                result += " <div class=cleaner>";
                result += "</div>";
                result += " <br />";
                result += "<div class=box_bottom>";
                result += " <span></span>";
                result += " </div>";
                result += " </div>";
     
            }
    Puis j'apel cette fonction dans la page aspx.cs :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
     
                this.literalConseil.Text = MConseil.MiseEnFormConseil(cat.ToString());
    Je ne sais pas du tout comment m'y prendre pour mettre en place la pagination, je commence même sérieusement a penser que mes fonctions ne sont pas adapter.

    PS : Je n'utilise pas de GridView qui serai trop contraignant a utiliser car je n'es pas une mise en forme tabulaire ( cf : Screenshots )



    Par avance merci pour votre aide.

  2. #2
    Membre très actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2011
    Messages
    255
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2011
    Messages : 255
    Par défaut
    Personne n'a une idée ?

  3. #3
    Membre très actif
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Octobre 2011
    Messages
    255
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Octobre 2011
    Messages : 255
    Par défaut
    J'avais penser a créer une fonction avec comme paramètre le nombre total de données et le nombre de données a afficher par 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
     
    private string AffichePage(int nbLigne, int nbLigneParPage)
            {
                string result = "";
                int nbPage = nbLigne / nbLigneParPage;
     
                if (nbPage == 1 )
                {
                    result += "";
                }
                if (nbPage > 1 && nbPage == 2)
                {
                    //Solution non viable.
                }
     
                return result;
            }
    Cette fonction est juste une ébauche de ce que je souhaiterai faire, mais je bloque toujours, je n'arrive pas a scinder mes liste et a attribué pour chaque parti de liste une page.

Discussions similaires

  1. Réponses: 2
    Dernier message: 21/09/2017, 17h55
  2. comment Créer un système de pagination automatique
    Par soufiane656 dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 30/06/2015, 13h07
  3. Commet créer un Système d'exploitation ?
    Par reggae dans le forum Langages de programmation
    Réponses: 31
    Dernier message: 25/07/2013, 11h54
  4. [MySQL] Système de pagination pour une galerie photo
    Par Badaboumpanpan dans le forum PHP & Base de données
    Réponses: 10
    Dernier message: 27/06/2006, 15h31
  5. [phpBB][2] Réalisation d'un système de pagination
    Par AlphonseBrown dans le forum Bibliothèques et frameworks
    Réponses: 8
    Dernier message: 26/10/2005, 11h26

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