Mon autre NavigationExercice a été réalisé en référence à la navigation de Guoke.com Lorsque j'ai vérifié le code source, j'ai trouvé que le code CSS de ce site Web est vraiment. clair et classe. L’organisation est également géniale. Même si je ne la comprends pas très bien, j’aime juste quand je la regarde.
Quand je vois cette navigation pour la première fois, il y a quelques éléments auxquels je dois réfléchir attentivement
1. Dans quel élément doit être imbriquée la petite icône de maison sur le devant de la page d'accueil
2. Comment le petit triangle en bas de la page d'accueil est-il implémenté ? le dos ?
4. Comment implémenter le
menu déroulant qui apparaît après avoir cliqué sur Plus ? Je n'implémenterai d'abord que le côté gauche, afin de pouvoir connecter de nombreux points de connaissances.
<p id="gheader"> <p class="gh-wrap"> <p class="fl"> <ul class="gh-nav reset"> <li> <a href=""> <span class="gnicon-home"></span> 首页 <b class="gnarrow-up"></b> </a> </li> <li><a href="">科学人</a></li> <li><a href="">小组</a></li> <li><a href="">问答</a></li> <li><a href="">Mooc学院</a></li> <li><a href="">知性</a></li> <li id='moreNav'> <a href="" class=""> 更多 <i class="gnarrow-down"></i> </a> <p class="gh-list"> <ul class="reset"> <li><a href="">日志</a></li> <li><a href="">活动</a></li> <li><a href="">在行</a></li> <li><a href="">十五言</a></li> <li><a href="">研究生</a></li> </ul> </p> </li> </ul> </p> </p> </p>
#gheader
La couche externe sert à indiquer la tête, et la couche interne peut être utilisée pour coiffer et ajuster la position de toute la partie tête .gh-wrap
2. Différent de l'exercice de navigation précédent, celui-ci est entouré de une autre couche à l'extérieur de
, car l'en-tête de la page Web d'origine a la navigation + ul
Recherche à gauche et les rappels de messages à droite. Un flotteur gauche et un flotteur droit. Cela rend la structure plus claire. 3.
. a
Définir vertical-line:middle; pour
image signifie placer l'image au milieu de la ligne, afin que l'image trouve le bas (image courte) ou le haut (hauteur de l'image).
J'ai donc pensé à une solution compatible. Choisissez de définir la hauteur de l'icône avant et de l'élément entourant le texte
à la même hauteur que l'image, et définissez la hauteur égale à la hauteur de la ligne, de sorte que le texte peut être centré. Le paramètre de l'image a
peut être aligné avec le haut ou le bas du texte à l'intérieur de a. Peut également être aligné horizontalement (ie6, 7). vertical-line:middle;
.gh-wrap .gh-nav li a{ display: inline-block; height: 18px; line-height: 18px; padding: 11px; text-decoration: none; color: #d5d5d5; } .gh-nav li a:hover{ background: #393939; color: #fff; } .gnicon-home{ background: url(gk/5-icon.png) transparent no-repeat; display: inline-block; vertical-align: middle; } .gh-nav a .gnicon-home{ background-position: 0 0; height: 18px; width: 16px; margin-right:5px ; }
car je dois définir la hauteur de a. Je crains que la largeur ne remplisse l'élément parent comme. Je m'en suis inquiété dans la note précédente, j'ai donc converti les éléments en ligne en éléments de niveau bloc en ligne. La méthode de conversion est également mentionnée dans cette note. En fait, j'ai également pris ici des notes sur les performances du navigateur moderne. a
2. Lorsque l'ingénieur front-end de Guoke.com a défini le style de l'icône avant, il a effectué les réglages séparément, défini la source de l'image d'arrière-plan, converti le formulaire de présentation et défini le centrage. à l'exception de la page d'accueil, les icônes Front peuvent également utiliser ce style public.
Ensuite, définissez un style distinct, définissez la position, la taille et les marges de l'image ainsi que d'autres paramètres spéciaux.
.gnarrow-down,.gnarrow-up{ line-height: 0; height: 0; width: 0; border: 4px solid transparent; color: #4c4c4c; } .gnarrow-up{ position: absolute; border-bottom-color: #85C155; bottom: 0; left: 50%; margin-left: -4px; } .gnarrow-down{ display: inline-block; vertical-align: middle; border-top-color:#d5d5d5 ; border-width: 3px; margin-left: 3px; } .gh-nav li a:hover{ background: #393939; color: #fff; } .gh-nav li a:hover i,.gh-nav li a:hover b{ color: #393939; }
1、设置这个三角,其实是很有技巧性的,觉得真的是对css了解的非常熟悉,才能想到这样的技巧。内容置空,宽度高度为0,设置其边框,然后通过分别设置上下左右的边框的颜色,可以获得各个方向的三角。
2、注意:color
这个属性具有继承性,他表示前景色,不仅设置文本的颜色,还设置了边框的颜色。在Exercices de navigation dans les pages Web (2)会发现识别不出透明色,然后通过分别设置前景色来改变border的颜色。
3、绿色箭头采用绝对定位。下拉箭头采用行内块级元素进行定位。
设置子菜单
#moreNav .gh-list{ position: absolute; right: 0; top: 40px; width: 80px; border: 1px solid #e0e0e0; box-shadow: 1px 1px 1px #f3f3f3; background: #fff; padding: 7px 0 8px; } #moreNav .gh-list li { /*之前设置过浮动*/ width: 100%; height: 25px; } #moreNav .gh-list li a{ /*之前设置过表现形式为行内块级元素,并设置过padding*/ width: 100%; height: 25px; text-align: center; line-height: 25px; padding: 0; } #moreNav .gh-list li a:hover{ background: #e0e0e0; }
1、子菜单需要进行绝对定位。
2、需要理解特制度的概念,我会专门写这个的,因为我们在编写css样式规则时,却发现这个规则先后顺序不一样,展示的效果不一样,css规则写的嵌套层次不一样,展示的结果可能也不一样,就像这里我们之前都设置过li>a
的样式,所以会对子菜单的样式有影响。
3、继承的样式即使靠的再进,也没有专门写过的样式优先级高。例如,line-height
具备继承性,所以我就不打算为a
写行高,但是a的行高却被之前设置的覆盖了,却没有继承父元素的样子。
第二步 设置包围元素样式
#gheader{ width: 100%; height: 43px; background: #4C4C4C; position: fixed; top: 0; left: 0; z-index: 999; } #gheader .gh-wrap{ height: 40px; min-width: 1030px; padding: 0 30px; border-bottom: 3px solid #85c155; }
1、这是一个头部固定的网页,但是position:fixed
一旦这么设置,必然导致其宽度收缩内容,这样就无法设置头部背景啦,于是设置宽度值为100%。
2、这里面的包围元素并没有要居中,而是以默认的格式。所以没有必要设置宽度,设置最小宽度就可以。当浏览器屏幕缩小时,也会有先收缩再维持的视觉效果。
3、发现a
里面有很对<b>
<span>
<i>
这类标签,注意,我都放在了<a>
里,因为这些行内元素,我们通过将其修饰,然后放置一些下拉箭头,首页图标,鼠标点击标记。
第三步:对导航元素进行基本布局
.fl{ float: left; } #moreNav p{ display: none; } .gh-wrap .gh-nav li{ float: left; position: relative; height: 40px; } .gh-wrap .gh-nav li a{ display: block; line-height: 40px; padding: 0 10px; text-decoration: none; color: #d5d5d5; }
1、我先隐藏了二级菜单
2、设置li
为相对定位,目的是有助于二级菜单的定位
3、a
的设置较之前一致
修饰导航
这就是基本的导航的设置。虽然看着很简单,但是只有自己编写了才会发现之间的一些小小的细节。
【相关推荐】
1. 免费css在线视频教程
2. css在线手册
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!