CSS3 实现导航栏_html/css_WEB-ITnose
导航栏是Web中常用的UI组件,在Bootstrap等CSS框架中基本都会提供。 既然导航栏这么重要,下面我们便来手动实现一个导航栏。 这个过程还是需要掌握一些排版技巧和CSS3特性的。
列表样式
导航栏通常使用
- 来标记:
- 上下添加额外的空白,可以设置
- 为 display: inline; 来克服。
边框和圆角
接着来设置一些边框和圆角:
ul a{ border-radius: 3px; border: 1px solid #e7e7e7; padding: 0 15px;}
登录后复制设置边框为稍微深的颜色,再加3像素圆角。设置内边距来让文字和边框有一定的距离。 border-radius 是CSS3特性,此前设置圆角还需要背景图的辅助,见 那些 CSS 背景图的技巧 。
注意设置 border 后,相邻项目的上下边框会连在一起形成2像素的边框。 可以设置负的外边距(让项目重叠1像素)来克服,但需要将最后一个项目的边距恢复为0。
ul a{ margin-bottom: -1px;}ul li:last-child a{ margin-bottom: 0;}
登录后复制高亮当前项
也许细心的读者可能注意到了,前述HTML片段中有一项
- 设置了 active 的CSS类。 它是为了标明当前高亮项目的。需要如下的样式:
ul .active a, ul a:hover{ background: #e7e7e7;}
登录后复制水平导航栏
水平导航有多种方式来实现。可以把
- 设置为 inline-block 让它水平排列, 也可以设置 float:left 让
- 水平浮动。我们介绍后者,先看图:
设置
- 水平浮动后,会使得父容器
- 的高度坍缩为零,它的背景设置将会失效。 在 利用浮动和清除浮动进行布局 一文中提到两种解决办法: 一是添加额外元素来清除浮动,二是让父容器也浮动。请看:
ul li{ float: left;}ul{ float: left;}
登录后复制与垂直导航类似,边框在水平方向会叠加起来。解决方法也是类似的:
ul a{ margin-right: -1px;}ul li:last-child a{ margin-right: 0;}
登录后复制
<ul> <li><a>First Item</a></li> <li><a>Second Item</a></li> <li class="active"><a>Third Item</a></li> <li><a>Fourth Item</a></li></ul>
首先便要去掉列表的那些默认样式,比如左边的向目标记(小圆点)和边距:
ul { left-margin: 0; /* IE/Opera 默认使用外边距 */ left-padding: 0; /* Safari/Firefox 默认使用内边距 */ list-style-type: none; /* 左侧向目标记 */}
这样便去掉了浏览器给
- 设置的默认样式了。 至于如何自定义左侧的项目标记,可参考 那些 CSS 背景图的技巧 一文。
既然
- 有这么多默认样式,为什么不直接用
垂直的导航栏
一个垂直的导航栏效果应当如下图,其中高亮(深色的)项目表示当前激活项, 表示鼠标悬停或当前页面。
上图使用的仍然是前述的HTML片段,下面主要考虑CSS的实现。 按照前述办法清除列表的默认样式后,来设置列表项的样式:
ul a{ display: block; width: 200px; height: 40px; line-height: 40px; background: #f8f8f8;}
首先将 设置为块级元素来设置它的宽高,然后设置行高与高相同来使文本居中。 最后设置一个背景来凸显一下导航栏。
注意IE会给

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

本文讨论了HTML&lt; Progress&gt;元素,其目的,样式和与&lt; meter&gt;元素。主要重点是使用&lt; progress&gt;为了完成任务和LT;仪表&gt;对于stati

本文讨论了html&lt; datalist&gt;元素,通过提供自动完整建议,改善用户体验并减少错误来增强表格。Character计数:159

本文讨论了使用HTML5表单验证属性,例如必需的,图案,最小,最大和长度限制,以直接在浏览器中验证用户输入。

本文讨论了HTML&lt; meter&gt;元素,用于在一个范围内显示标量或分数值及其在Web开发中的常见应用。它区分了&lt; meter&gt;从&lt; progress&gt;和前

本文讨论了视口元标签,这对于移动设备上的响应式Web设计至关重要。它解释了如何正确使用确保最佳的内容缩放和用户交互,而滥用可能会导致设计和可访问性问题。

本文讨论了&lt; iframe&gt;将外部内容嵌入网页,其常见用途,安全风险以及诸如对象标签和API等替代方案的目的。

HTML适合初学者学习,因为它简单易学且能快速看到成果。1)HTML的学习曲线平缓,易于上手。2)只需掌握基本标签即可开始创建网页。3)灵活性高,可与CSS和JavaScript结合使用。4)丰富的学习资源和现代工具支持学习过程。
