CSS 下拉菜单

使用 CSS 创建一个鼠标移动上去后显示下拉菜单的效果。

下拉菜单实例:

当鼠标移动到指定元素上时,会出现下拉菜单。

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"> 
  <title>php.cn</title>
   <style type="text/css">
     ul,ol,li
     {list-style:none;padding:0px;margin:0px;}
     #menu *
     {line-height:30px;z-index:10;}
     #menu a
     {
      text-decoration:none;
      display:block;
     }
     #menu ul
     {
     text-align:left;
     background:#333;
     }
      #menu .arrow  /* 菜单项的右侧小箭头  */
     {
     float:right;
     padding-right:5px;
     }
     #menu li:hover>ul
     {display:block;}
     #menu>ul{height:30px;} /* 即使没有菜单项也能保持顶级菜单栏的高度。 */
     /* 一级菜单 */
     #menu>ul>li
    {
     text-align:center;
     display:inline-block;
     width:80px;
     }
     #menu>ul>li>a
    {color:#fff;}
     #menu>ul>li:hover
    {background:#666;}
     /* 下拉的菜单栏 */
     #menu>ul>li ul
     {
     display:none;
     width:150px;
     position:absolute;
     background:#c1cd94;
     box-shadow:2px 2px 2px #000;
     -webkit-box-shadow:2px 2px 2px #000;
     -moz-box-shadow:2px 2px 2px #123;
     }
     /* 下拉菜单的菜单项 */
     #menu>ul>li>ul li
    {padding-left:5px; position:relative;}
    #menu>ul>li>ul li>a
    {color:#000;}
    #menu>ul>li>ul li:hover
    {background:#d3dbb3;}
   </style>
<body>
  <div id="menu">
<ul>
  <li><a href="">菜单一</a>
<ul>
 <li><a href="">子菜单1</a></li>
 <li><a href="">子菜单2</a>
<ul><li><a href="">子菜单7</a></li></ul>
 </li>
 <li><a href="">子菜单3</a></li>
    </ul>
  </li>
  <li><a href="">菜单二</a>
  <ul>
<li><a href="">子菜单4</a></li>
<li><a href="">子菜单5</a></li>
<li><a href="">子菜单6</a></li>
  </ul>
  </li>
</ul>
  </div>
</body>
</html>

创建下拉菜单,并允许用户选取列表中的某一项:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"> 
<title>php.cn</title>
<style type="text/css">
     /* 下拉按钮样式 */
.dropbtn {
    background-color: black;
    color: white;
    padding: 16px;
    font-size: 16px;
    border: none;
    cursor: pointer;
}
/* 容器 <div> - 需要定位下拉内容 */
.dropdown {
    position: relative;
    display: inline-block;
}
/* 下拉内容 (默认隐藏) */
.dropdown-content {
    display: none;
    position: absolute;
    background-color: #f9f9f9;
    min-width: 160px;
    box-shadow: 0px 8px 16px 0px rgba(0,0,0,0.2);
}
/* 下拉菜单的链接 */
.dropdown-content a {
    color: black;
    padding: 12px 16px;
    text-decoration: none;
    display: block;
}
/* 鼠标移上去后修改下拉菜单链接颜色 */
.dropdown-content a:hover {background-color: yellow;}
/* 在鼠标移上去后显示下拉菜单 */
.dropdown:hover .dropdown-content {
    display: block;
}
/* 当下拉内容显示后修改下拉按钮的背景颜色 */
.dropdown:hover .dropbtn {
    background-color: #3e8e41;
}
</style>
<body>
 <div class="dropdown">
  <button class="dropbtn">下拉菜单</button>
  <div class="dropdown-content">
    <a href="#">菜单栏 1</a>
    <a href="#">菜单栏 2</a>
    <a href="#">菜单栏 3</a>
  </div>
</div>
</body>
</html>

注释:

HTML 部分:

我们可以使用任何的 HTM,元素来打开下拉菜单,如:<span>, 或 a <button> 元素。

使用容器元素 (如: <div>) 来创建下拉菜单的内容,并放在任何你想放的位置上。

使用 <div> 元素来包裹这些元素,并使用 CSS 来设置下拉内容的样式。

CSS 部分:

.dropdown 类使用 position:relative, 这将设置下拉菜单的内容放置在下拉按钮 (使用 position:absolute) 的右下角位置。

.dropdown-content 类中是实际的下拉菜单。默认是隐藏的,在鼠标移动到指定元素后会显示。 注意 min-width 的值设置为 160px。你可以随意修改它。 注意: 如果你想设置下拉内容与下拉按钮的宽带一致,可设置 width 为 100% ( overflow:auto 设置可以在小尺寸屏幕上滚动)。

我们使用 box-shadow 属性让下拉菜单看起来像一个"卡片"。



Weiter lernen
||
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title>php.cn</title> <style type="text/css"> *{ margin:0px; padding:0px;} #nav{ width:600px; height:40px; margin:0 auto;} #nav ul{ list-style:none;} #nav ul li{ float:left; line-height:40px; text-align:center; position:relative;} #nav ul li a{ text-decoration:none; color:#000; display:block;padding:0px 10px;} #nav ul li a:hover{ color:#FFF; background:#333} #nav ul li ul{ position:absolute; display:none;} #nav ul li ul li{ float:none; line-height:30px; text-align:left;} #nav ul li ul li a{ width:100%;} #nav ul li ul li a:hover{ background-color:#06f;} #nav ul li:hover ul{ display:block} </style> </head> <div id="nav"> <ul> <li><a href="#">首页</a></li> <li><a href="#">学习中心</a> <ul> <li><a href="#">java</a></li> <li><a href="#">jQuery</a></li> <li><a href="#">CSS</a></li> <li><a href="#">HTML</a></li> </ul> </li> <li><a href="#">个人中心</a></li> <li><a href="#">关于我们</a></li> </ul> </div> <body> </body> </html>
einreichenCode zurücksetzen