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

PHP & Base de données Discussion :

navigation page par page [Fait]


Sujet :

PHP & Base de données

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Profil pro
    Technicien Informatique
    Inscrit en
    Février 2006
    Messages
    187
    Détails du profil
    Informations personnelles :
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Technicien Informatique

    Informations forums :
    Inscription : Février 2006
    Messages : 187
    Par défaut navigation page par page
    Bonjour à tous !

    Je suis entrain d'essayer de mettre en place une naviguation page par page...j'utilise le code suivant mais ...il ne me parait pas génial car il ne fonctionne pas correctement
    n'y a t'il pas moyen de faire plus simple et plus efficace ?
    auriez vous un lien à me soumettre exposant un exemple de code ?

    Merci a tous pour vos suggestions et explications

    Jean Marc




    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
     
     
    <?
    include("connexion.php");
    //nombre d'enregistrements par page
    $nombre=20;
    //si limite=0
    if(!isset($limite))$limite=0;
    $path_parts=pathinfo($_SERVER['PHP_SELF']);
    $page=$path_parts ["basename"];
    //compter le nombre d'enregistrements
    $select='select count(id) from agents';
    //effectuer la requete
    $result=mysql_query($select,$connexion) or die('Erreur:'.mysql_error());
    $row=mysql_fetch_row($result);
    // le total est placé dans un tableau row en première position
    $total=$row[0];
    // requete en fonction du nombre d'enregistrements
    $select='select * from agents order by nom asc limit'.$limite.','.$nombre;
    //$result=mysql_query($select,$connexion) or die('Erreur:'.mysql_error());
    //limite suivante
    $limitesuivante=$limite+$nombre;
    //limite precedente
    $limiteprecedente=$limite-$nombre;
    //si limite different de 0
    if($limite !=0){
    //affiche page précédente
    echo '<a href="'.$page.'?limite='.$limiteprecedente.'">Page précédente</a>';
    }
    //si limite suivante inférieure à totale
    if($limitesuivante<$total){
    echo '<a href="'.$page.'?limite='.$limitesuivante.'">Page suivante</a>';
    }
    //récupération de $limite
    if(isset($_GET['limite']))
    $limite=$_GET['limite'];
    else $limite=0;
    function verifLimite($limite,$total,$nombre){
    if(is_numeric($limite)){
    if($limite>=0)&&($limite<=$total)&&(($limite%$nombre)==0)){
    $valide=1;
    }
    else
    {
    $valide=0;
    }
    }
    else
    {
    $valide=0;
    }
    return $valide;
    }
    function displayNextPreviousButtons($limite,$total,$nb,$page){
    $limiteSuivante=$limite+$nb;
    $limitePrecedente=$limite-$nb;
    echo'<table><tr>'."\n";
    if limite(!=0){
    echo'<td valign="top>'."\n";
    echo '<form action="'.$page.'"method="post">'."\n";
    echo '<input type="submit" value="précédents">'."\n";
    echo '<input type="hidden" value="'.$limitePrecedente.'"name="limite">'."\n";
    echo '</form>'."\n";
    echo '</td>'."\n";
    }
    echo '</tr></table>'."\n";
    }
    }
    if limite($limiteSuivante<$total){
    }
    }
    echo '</tr></table>'."\n";
    }
    function(affichePages($nb,$page,$total){
    $nbpages=ceil($total/$nb);
    $numeroPages=1;
    $compteurPages=1;
    $limite=0;
    echo'<table border="0"><tr>'."\n";
    echo'<td><a href="'.$page.'?limite='.$limite.'">'.$numeroPages.'</a></td>'."\n";
    $limite=$limite+$nb;
    $numeroPages=$numeropages +1;
    $compteurPages=$compteurPages+1;
    if($compteurPages==10);{
    $compteurPages=1;
    echo'<br>'."\n";
    }
    }
    ?>

  2. #2
    Rédacteur
    Avatar de RideKick
    Homme Profil pro
    Directeur technique
    Inscrit en
    Septembre 2006
    Messages
    5 914
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : Directeur technique
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Septembre 2006
    Messages : 5 914
    Pas de questions techniques en MP please

    Mon site perso

    Mon profil Viadeo

Discussions similaires

  1. [SQL] Script d'affichage page par page
    Par x2thez dans le forum PHP & Base de données
    Réponses: 8
    Dernier message: 10/05/2006, 15h48
  2. [MySQL] Affichage page par page et requêtes du type $sql .=
    Par carelha dans le forum PHP & Base de données
    Réponses: 7
    Dernier message: 06/04/2006, 17h12
  3. [Tableaux] PB liens apres affichage page par page
    Par x2thez dans le forum Langage
    Réponses: 16
    Dernier message: 15/03/2006, 16h58
  4. [MySQL] afficher plusieurs enregistrements par page par page à la volée
    Par pod1978 dans le forum PHP & Base de données
    Réponses: 4
    Dernier message: 14/03/2006, 12h22
  5. [struts] afficher page par page une liste d'élément
    Par BurningPat dans le forum Struts 1
    Réponses: 6
    Dernier message: 27/09/2005, 11h09

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