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 :

menu en php avec css


Sujet :

Langage PHP

  1. #1
    Nouveau Candidat au Club
    Inscrit en
    Septembre 2011
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Septembre 2011
    Messages : 2
    Points : 1
    Points
    1
    Par défaut menu en php avec css
    Bonjour à tous.

    J'écrit pour la première fois sur ce forum, car j'ai un souci php que je n'arrive pas à résoudre.

    Je tente de mettre le menu de mon site web en php avec requète Mysql.
    Les menus s'affichent correctement pas de problème.
    Mon seul souci est que je veux qu'il y ai une alternance de css entre les liens
    exp :
    lechat.php avec la class 1
    lechien.php avec la class 2
    lecanard.php avec la class 1
    etc...

    Je pensais faire cela à l'aide d'un champs 'classe' de ma table, la remplir de chiffre et faire au moyen des chiffres pair et impair.

    Mais je n'arrive pas à le coder.

    Quelqu'un peut il m'aider ?

    Merci d'avance pour vos réponses

  2. #2
    Membre actif
    Homme Profil pro
    Première S
    Inscrit en
    Juillet 2010
    Messages
    266
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France

    Informations professionnelles :
    Activité : Première S

    Informations forums :
    Inscription : Juillet 2010
    Messages : 266
    Points : 281
    Points
    281
    Par défaut
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    $i=1;
    while($data = $requete->fetch()){
        // boucle de parcours des résultats de la requête
       // là, une condition pour savoir quelle attribut utiliser :
       echo '<span class='.$i.' >lien</span>';
      $i= $i==1?2:1; // conditions ternaires
    }

    voilà, en fait, " $i= $i==1?2:1; " ça veux dire :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    if($i==1){
    $i=2;
    }else{
    $i=1;
    }
    voilà, comme ça au premier tout i = 1, au deuxième i =2 au troisième i=1 etc.

    NB

    ceci n'est qu'un moyen parmi beaucoup d'autre.

  3. #3
    Membre confirmé Avatar de Inazo
    Profil pro
    Gérant - société de développement web
    Inscrit en
    Avril 2007
    Messages
    417
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations professionnelles :
    Activité : Gérant - société de développement web
    Secteur : High Tech - Multimédia et Internet

    Informations forums :
    Inscription : Avril 2007
    Messages : 417
    Points : 632
    Points
    632
    Par défaut
    Bonjour,

    La solution de Dominique49 fonctionne, je vais donner une autre solution par contre attention les class et id ne peuvent commencer par un nombre (W3C).

    Donc pour ma part dans ces cas là je suis pour 0 ou 1.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
     
    $i=0;
     
    while($data = $requete->fetch()){
        // boucle de parcours des résultats de la requête
       // là, une condition pour savoir quelle attribut utiliser :
      echo '<span class="ClassMenu'.$i.'">lien</span>';
     
      $i =! $i; // conditions ternaires
    }
    Donc le code $i =! $i; fait la chose suivante :

    Si $i == 1 Alors $i = 0
    Si $i == 0 Alors $i = 1

    Cordialement,
    PS : n'oubliez pas non plus vos " " pour les attributs HTML un jour vous aurez des surprises sinon.

  4. #4
    Membre actif
    Homme Profil pro
    Première S
    Inscrit en
    Juillet 2010
    Messages
    266
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 28
    Localisation : France

    Informations professionnelles :
    Activité : Première S

    Informations forums :
    Inscription : Juillet 2010
    Messages : 266
    Points : 281
    Points
    281
    Par défaut
    bravo, encore plus performant (et aux normes)

  5. #5
    Nouveau Candidat au Club
    Inscrit en
    Septembre 2011
    Messages
    2
    Détails du profil
    Informations forums :
    Inscription : Septembre 2011
    Messages : 2
    Points : 1
    Points
    1
    Par défaut Merci
    Merci beaucoup pour vos réponses, je vais essayer de mettre tout cela en pratique !^^

    Bien cordialement

  6. #6
    Expert éminent
    Avatar de Séb.
    Profil pro
    Inscrit en
    Mars 2005
    Messages
    5 199
    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 199
    Points : 8 424
    Points
    8 424
    Billets dans le blog
    17
    Par défaut
    Juste pour info on peut faire la même chose en CSS3-only.

    Par exemple :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    .classMenu:nth-child(odd) { background-color : transparent }
    .classMenu:nth-child(even) { background-color : lemonchiffon }
    http://www.w3.org/TR/css3-selectors/#nth-child-pseudo

Discussions similaires

  1. menu en php avec lien actif en css
    Par serna dans le forum Langage
    Réponses: 4
    Dernier message: 21/10/2014, 11h23
  2. Réaliser un menu au survol avec CSS
    Par thibaud74 dans le forum Mise en page CSS
    Réponses: 1
    Dernier message: 07/03/2008, 09h25
  3. En tête php avec css
    Par piotrr dans le forum Mise en page CSS
    Réponses: 12
    Dernier message: 28/12/2007, 23h33
  4. [PostgreSQL] [PostGreSQL] menu dynamique php-postgre-css
    Par tyrann dans le forum PHP & Base de données
    Réponses: 6
    Dernier message: 02/11/2005, 17h23

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