Une barre de navigation (navbar) bien conçue et fonctionnelle est l'un des éléments clés de tout site Web. Il sert de feuille de route aux utilisateurs, les aidant à naviguer à travers les différentes pages. Une barre de navigation est généralement positionnée en haut d'une page Web, où elle est toujours visible pour que les utilisateurs puissent accéder aux liens clés. Dans cet article, nous explorerons comment créer une barre de navigation CSS visuellement attrayante et fonctionnelle en utilisant HTML et CSS. Nous aborderons également diverses techniques pour garantir que la barre de navigation reste en haut de la page.
Vous pouvez consulter une démo en direct de cette barre de navigation et explorer ses fonctionnalités en visitant l'aperçu sur CodePen.
L'extrait de code suivant illustre la création d'une barre de navigation réactive avec un logo, des éléments de menu et un bouton d'appel à l'action. Voici le code HTML et CSS :
Navbar
Décrypter le code
Examinons de plus près comment la barre de navigation est créée à l'aide de HTML et CSS.
La partie HTML du code est simple. Il se compose d'un élément nav qui contient trois composants principaux :
Le logo est créé à l'aide d'une balise . Le menu est une liste non ordonnée ()
qui contient des éléments de liste (
La magie opère dans la section CSS, où nous définissons la disposition et l'apparence de la barre de navigation. Discutons de certains des éléments clés.
Style d'arrière-plan et de corps
Le corps a un fond dégradé qui passe du bleu (#2258c3) au rose (#fd2df3). La hauteur est définie sur 100vh (hauteur de la fenêtre), ce qui garantit que l'arrière-plan remplit tout l'écran et qu'il n'y a aucune marge pour éviter tout espace indésirable autour de la page.
body { background: linear-gradient(0deg, #2258c3 10%, #fd2df3 90%); height: 100vh; margin: 0; padding-top: 10px; }
La barre de navigation a un fond blanc et des coins arrondis (border-radius : 30px). Le remplissage et la marge créent un espacement à l'intérieur et à l'extérieur de la barre de navigation. La propriété display: flex fait de la barre de navigation une flexbox, permettant l'alignement horizontal de ses éléments enfants. Le justifier-contenu : espace-entre garantit que le logo, le menu et le bouton sont uniformément espacés.
.navbar { display: flex; background: #fff; border-radius: 30px; padding: 10px 20px; margin: 0 auto; width: 95%; justify-content: space-between; align-items: center; }
L'une des fonctionnalités clés d'une barre de navigation est de rester en haut de la page lors du défilement. Pour y parvenir, nous utilisons la position : propriété fixe. Cela permet à la barre de navigation de rester fixe en haut (top : 0) quel que soit le défilement. De plus, le z-index : 9999 garantit que la barre de navigation est toujours au-dessus des autres éléments de la page.
.navbar { position: fixed; top: 0; left: 0; right: 0; z-index: 9999; }
Les éléments de menu sont affichés horizontalement à l'aide de display: flex sur la classe .menu. Les éléments sont espacés dans la marge et chaque élément est stylisé pour supprimer le style de liste et le remplissage par défaut. Les liens dans les éléments de menu n'ont pas de décorations de texte et sont stylisés avec une police en gras et une couleur sombre.
L'effet de survol sur les liens modifie la couleur pour qu'elle corresponde à la couleur d'arrière-plan bleu (#2258c3), fournissant un signal visuel indiquant que le lien est interactif.
.menu { display: flex; list-style-type: none; margin: 0; padding: 0; } .item { margin: 0 15px; } .item a { text-decoration: none; color: #333; font-weight: bold; } .item a:hover { color: #2258c3; }
Le bouton est doté d'un fond bleu (#2258c3), de texte blanc et de coins arrondis (border-radius : 20px). Au survol, l'arrière-plan devient rose (#fd2df3) pour correspondre au dégradé de l'arrière-plan.
button { background-color: #2258c3; color: white; border: none; padding: 10px 20px; border-radius: 20px; cursor: pointer; } button:hover { background-color: #fd2df3; }
Pour corriger l'en-tête en haut de la page avec CSS, vous utilisez la propriété position: fixed avec top: 0. Cela garantit que la barre de navigation restera en haut pendant que l'utilisateur fait défiler. Voici comment cela est appliqué dans le code :
.navbar { position: fixed; top: 0; left: 0; right: 0; z-index: 9999; }
Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.
Copyright© 2022 湘ICP备2022001581号-3