个人练习:使用HTML+CSS制作二级菜单
最近一直在学习HTML+CSS,刚看完如果制作下拉菜单部分,就想着做一个练练手。
先上成品图:
就是上面这个效果,横向菜单选项能点击,鼠标放在上面也能展开二级菜单,二级菜单也能点击,点击后就会在底下的<iframe>中打开网站链接。(可能这里会有人好奇"为什么不点开哔哩哔哩你不是都放在上面了嘛!",实际上我这边点开哔哩哔哩它会跳转两次,先在<iframe>中打开一次,然后又会在当前页面转到哔哩哔哩,你得后退一次才能看到在<iframe>中打开的哔哩哔哩_(:з」∠)_)
那么不废话了直接切入正题。
我的设想是创建两个<div>,宽度都是占100%,顶上的<div>放菜单栏,下面的<div>专门放<iframe>(这里先给两个区域设置背景颜色好分辨):
1 <!-- 顶部div区域,存放横向导航栏 --> 2 <div class="topMenu"> 3 4 </div> 5 6 <!-- 主要内容的div区域,存放网站页面的框架 --> 7 <div class="mainContent"> 8 9 </div>
底端的<div>区域我希望高度是除去顶端元素后剩余的所有部分,这里就用到了CSS3中的一个函数calc()。:
1 /* 清除文档内外边距,让<div>区域能够紧贴浏览器边缘 */ 2 body { 3 padding:0px; 4 margin:0px; 5 } 6 7 /* 设置顶部<div>区域样式 */ 8 .topMenu { 9 z-index:1; /* 设置元素堆叠顺序,保证菜单能出现在最前端 */ 10 11 width:100%; /* 设置宽度 */ 12 height:50px; /* 设置指定高度。如果想要增加顶部横向导航栏的高度设置这个 */ 13 background-color:#000000; /* 设置背景颜色,让没有列表项的位置也有颜色,看起来不违和 */ 14 } 15 /* 设置底部<div>区域样式 */ 16 .mainContent { 17 position:absolute; /* 这个定位是为了让这个<div>区域固定在页面底端 */ 18 bottom:0px; /* 让它定位在底端 */ 19 overflow:hidden; /* 溢出部分隐藏,防止出现第二个滚动条 */ 20 z-index:-1; /* 设置元素堆叠顺序为最底层,为了不让它遮住下拉菜单的垂直列表项 */ 21 22 width:100%; /* 设置宽度 */ 23 /* 因为不是所有浏览器都支持CSS3中的calc()方法,所以这里写了三条去设置高度 */ 24 height:-webkit-calc(100% - 50px); 25 height:-moz-calc(100% - 50px); 26 height:calc(100% - 50px); 27 background-color:#CDCDCD; /* 这个背景颜色是测试用的,想删除可以删除 */ 28 }
这个时候我们的两个区域就创建好啦:
接下来我们将列表项和底部用的<iframe>框架写进去,在<head>中添加<base>标签指示点击的链接都在框架中打开:
1 <head> 2 <meta charset="UTF-8"> 3 <title>使用HTML+CSS制作二级菜单</title> 4 <!-- 链接到外部样式表 --> 5 <link rel="stylesheet" type="text/css" href="使用HTML+CSS制作二级菜单.css" /> 6 <!-- 设置所有超链接单击的时候的打开方式为在框架"isFrame"中打开 --> 7 <base target="isFrame" /> 8 </head> 9 10 <body> 11 <!-- 顶部div区域,存放横向导航栏 --> 12 <div class="topMenu"> 13 <!-- 一级菜单 --> 14 <ul> 15 <!-- 二级菜单:菜鸟教程 --> 16 <li class="dropdown"> 17 <a href="http://www.runoob.com/"> 18 菜鸟教程 19 </a> 20 <ul class="dropdown-content"> 21 <li> 22 <a href="http://www.runoob.com/html/html-tutorial.html">HTML教程</a> 23 </li> 24 <li> 25 <a href="http://www.runoob.com/css/css-tutorial.html">CSS教程</a> 26 </li> 27 <li> 28 <a href="http://www.runoob.com/html/html5-intro.html">HTML5教程</a> 29 </li> 30 <li> 31 <a href="http://www.runoob.com/css3/css3-tutorial.html">CSS3教程</a> 32 </li> 33 </ul> 34 </li> 35 <!-- 二级菜单:indienova --> 36 <li class="dropdown"> 37 <a href="https://indienova.com/"> 38 indienova 39 </a> 40 <ul class="dropdown-content"> 41 <li> 42 <a href="https://indienova.com/indie-game-news/">文章</a> 43 </li> 44 <li> 45 <a href="https://indienova.com/column/">专题</a> 46 </li> 47 <li> 48 <a href="https://indienova.com/indie-game-development/">开发</a> 49 </li> 50 <li> 51 <a href="https://indienova.com/usergames">游戏</a> 52 </li> 53 </ul> 54 </li> 55 <!-- 二级菜单:哔哩哔哩动画 --> 56 <li class="dropdown"> 57 <a href="https://www.bilibili.com/"> 58 哔哩哔哩动画 59 </a> 60 <ul class="dropdown-content"> 61 <li> 62 <a href="https://www.bilibili.com/v/douga/?spm_id_from=333.334.b_7072696d6172795f6d656e75.2">动画</a> 63 </li> 64 <li> 65 <a href="https://www.bilibili.com/anime/?spm_id_from=333.334.b_7072696d6172795f6d656e75.7">番剧</a> 66 </li> 67 </ul> 68 </li> 69 <!-- 右浮动的一级菜单选项:百度 --> 70 <li id="baiDu"> 71 <a href="https://www.baidu.com/"> 72 百度 73 </a> 74 </li> 75 </ul> 76 </div> 77 78 <!-- 主要内容的div区域,存放网站页面的框架 --> 79 <div class="mainContent"> 80 <!-- 显示在菜单中点击的链接用的框架 --> 81 <iframe name="isFrame"></iframe> 82 </div> 83 84 </body>
这个时候效果是这样的:
这里因为<ul>的外边距(margin)的关系页面顶端被顶出了一段空间,左侧被内边距(padding)顶出了一段空间,只需要将这两个属性设置为0px即可。还需要去除无序列表的标示(list-style-type:none),顺便设置一下框架的样式:
1 /* 设置显示网站页面框架的属性,因为只有一个框架我就直接设置<iframe>的属性 */ 2 iframe { 3 width:100%; 4 height:100%; 5 border:none; /* 去除它自带的边框 */ 6 } 7 8 /* 设置顶部<div>区域中的<ul>样式 */ 9 .topMenu ul{ 10 margin:0px; /* 去除外边距,使其能够紧贴<div>边缘 */ 11 padding:0px; /* 去除内边距,使其能够紧贴<div>边缘 */ 12 list-style-type:none; /* 去除无序列表的标识符 */ 13 }
将最外层的列表中的列表项<li>设置成横向:
1 /* 设置header区域中的水平列表的<li>标签的样式 */ 2 li { 3 float:left; /* 设置左浮动,让它列表项的方向变成水平方向 */ 4 background-color:#000000; /* 设置背景颜色 */ 5 text-align:center; /* 设置水平对齐方式为居中 */ 6 width:150px; /* 设置固定宽度 */ 7 border-right:solid 2px #FFFFFF; /* 设置右边框作为分割标签的标志 */ 8 }
设置一下<a>标签的样式,修改字体颜色(color)和去除下划线(text-decoration),让它的高度(height)和我们设置的顶端<div>的高度一致,为了让它的点击区域能够充满<li>标签,我们将其转换为块级元素(display:block):
1 /* 设置header区域中的<a>标签的初始样式 */ 2 a { 3 display:block; /* 转换为块级元素,为了让点击范围能够扩充到整个<li>区域 */ 4 line-height:50px; /* 设置内边距让文字垂直居中。 */ 5 color:#FFFFFF; /* 修改文字初始颜色 */ 6 text-decoration:none; /* 去除<a>标签的下划线 */ 7 }
已经可以看出样子了。
接下来我们把二级菜单隐藏起来(display:none)。在之前写这个菜单列表的时候我已经给每一个二级菜单的<ul>都增加了一个类(class:dropdown-content),那么我们CSS的样式部分直接对这个类的所有<ul>标签进行设置就行啦:
1 /* 隐藏所有二级菜单 */ 2 ul.dropdown-content { 3 display:none; /* 设置显示属性为none */ 4 }
二级菜单就都不见了,那我们该怎么看见二级菜单勒?我们可以设置当鼠标悬停在有二级菜单的选项上的时候(:hover)将显示属性设置为块(display:block)或者是它最初的属性列表(display:list-item)都行,在这个例子中我选择了列表(display:list-item)。在前面我也给每个包含二级菜单的<li>标签都增加了一个类(class:dropdown),也是直接设置这个类属性就行了:
1 /* 当鼠标放置在有下拉列表的<li>对象上时 */ 2 li.dropdown:hover ul { 3 display:list-item; /* 转换为列表元素,让其恢复显示 */ 4 }
鼠标放上去没有个明显的视觉反馈,盯着左下角这也太蛋疼了,那么我们设置下当鼠标放置在每个选项上面的时候(:hover)背景颜色(background-color)和字体颜色(color)会发生变化:
1 /* 修改<div class="header">中,鼠标放在<li>标签上时的样式 */ 2 div.topMenu li:hover { 3 background-color:#E4E4E4; 4 } 5 6 /* 当<li>标签处于激活时<li>的<a>子标签的样式 */ 7 li:hover>a{ 8 color:#000000; 9 }
为什么设置的是<li>的背景而不是<a>标签的背景颜色呢?因为在我之前自己测试一遍的时候,设置<a>标签的背景颜色有时候会出现一个缝隙,我找不到解决的方法,就干脆设置<li>的背景颜色好啦┓( ´∀` )┏(你看右边那里,有个缝隙):
大致效果基本上已经实现的差不多了,接下来就是一些样式的细化了。比如说现在二级菜单的<li>还残留这我们设置用来隔离横向菜单选项(一级菜单)的边框,我想要二级菜单比一级菜单更宽一点,二级菜单中的文本左对齐:
1 /* 设置二级菜单的<li>标签样式 */ 2 ul.dropdown-content li { 3 border-right:transparent; /* 去除在一级菜单中设置的用于分隔标签的边框 */ 4 width:200px; /* 设置指定宽度,保证所有选项宽度一致 */ 5 text-align:left; /* 下拉列表的文字对齐方式为左对齐,不使用横向列表的居中属性 */ 6 padding-left:20px; /* 设置左侧内边距偏移,不让它紧贴边缘 */ 7 }
在二级菜单顶端加一个蓝色边框区分下二级菜单和一级菜单的分界,这个就只需要设置每一个二级菜单中的第一个<li>标签的样式(li:first-of-type)即可:
1 /* 给每一个垂直列表的第一个列表项加上一个蓝色的顶部边框 */ 2 .dropdown li:first-of-type { 3 border-top:solid 2px blue; 4 }
把"百度"这个选项放到最右边,有特别的样式:
1 /* 修改<div class="header">中,鼠标放在"百度"的<li>标签上时的样式 */ 2 div.topMenu li#baiDu:hover { 3 background-color:#E30000; 4 } 5 6 /* 该属性会在设置当<li>标签处于激活时<li>的<a>子标签的样式 */ 7 li#baiDu:hover a { 8 /* 为了看得清改变背景后的子,单独设置颜色 */ 9 color:#FFFFFF; 10 }
晚些时候我会把这个例子的文件上传网盘贴链接在这里。
百度云:https://pan.baidu.com/s/1FxhctaQvZmX8l4IAwZkd0A
如果本文中有哪里有问题欢迎留言指出。本人还是个菜鸟(英语甚至小学生不如,我会好好努力的!),哪里写的有问题自己不一定能马上发现,您指出来那真是帮上大忙了。