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 屬性讓下拉式選單看起來像一個"卡片"。



#
繼續學習
||
<!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>