CSS 導航欄


CSS 導航欄

一、導航欄

熟練使用導航欄,對於任何網站都非常重要。

使用CSS你可以轉換成好看的導航欄而不是枯燥的HTML菜單。

二、導航欄=鏈接列表

作為標准的HTML基礎一個導航欄是必須的。

在我們的例子中我們將建立一個標准的HTML列表導航欄。

導航條基本上是一個鏈接列表,所以使用 <ul> 和 <li>元素非常有意義:

<ul>
  <li><a href="#home">主頁</a></li>
  <li><a href="#news">新聞</a></li>
  <li><a href="#contact">聯系</a></li>
  <li><a href="#about">關於</a></li>
</ul>

注意:這里我們用 href="#"作為測試連接。但在一個真正的 web 站點上需要真實的 url。

現在,讓我們從列表中刪除邊距和填充:

ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
}

例子解析:

  • list-style-type:none - 移除列表前小標志。一個導航欄並不需要列表標記
  • 移除瀏覽器的默認設置將邊距和填充設置為0

上面的例子中的代碼是垂直和水平導航欄使用的標准代碼。

三、垂直導航欄

上面的代碼,我們只需要 <a>元素的樣式,建立一個垂直的導航欄:

a
{
    display:block;
    width:60px;
}

示例說明:

  • display:block - 顯示塊元素的鏈接,讓整體變為可點擊鏈接區域(不只是文本),它允許我們指定寬度
  • width:60px - 塊元素默認情況下是最大寬度。我們要指定一個60像素的寬度

注意: 請務必指定 <a>元素在垂直導航欄的的寬度。如果省略寬度,IE6可能產生意想不到的效果。

四、垂直導航條實例

創建一個簡單的垂直導航條實例,在鼠標移動到選項時,修改背景顏色:

ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
    width: 200px;
    background-color: #f1f1f1;
}
 
li a {
    display: block;
    color: #000;
    padding: 8px 16px;
    text-decoration: none;
}
 
/* 鼠標移動到選項上修改背景顏色 */
li a:hover {
    background-color: #555;
    color: white;
}

五、激活/當前導航條實例

在點擊了選項后,我們可以添加 "active" 類來標准哪個選項被選中:

.active {
    background-color: #4CAF50;
    color: white;
}

六、創建鏈接並添加邊框

可以在 <li> or <a> 上添加text-align:center 樣式來讓鏈接居中。

可以在 border <ul> 上添加 border 屬性來讓導航欄有邊框。如果要在每個選項上添加邊框,可以在每個 <li> 元素上添加border-bottom :

ul {
    border: 1px solid #555;
}
 
li {
    text-align: center;
    border-bottom: 1px solid #555;
}
 
li:last-child {
    border-bottom: none;
}

七、全屏高度的固定導航條

接下來我們創建一個左邊是全屏高度的固定導航條,右邊是可滾動的內容。

ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
    width: 25%;
    background-color: #f1f1f1;
    height: 100%; /* 全屏高度 */
    position: fixed; 
    overflow: auto; /* 如果導航欄選項多,允許滾動 */
}

注意: 該實例可以在移動設備上使用。

八、水平導航欄

有兩種方法創建橫向導航欄。使用內聯(inline)浮動(float)的列表項。

這兩種方法都很好,但如果你想鏈接到具有相同的大小,你必須使用浮動的方法。

1,內聯列表項

建立一個橫向導航欄的方法之一是指定元素, 上述代碼是標准的內聯:

li
{
    display:inline;
}

實例解析:

  • display:inline; -默認情況下,<li>元素是塊元素。在這里,我們刪除換行符之前和之后每個列表項,以顯示一行。

2,浮動列表項

在上面的例子中鏈接有不同的寬度。

對於所有的鏈接寬度相等,浮動 <li>元素,並指定為 <a>元素的寬度:

li
{
    float:left;
}
a
{
    display:block;
    width:60px;
}

實例解析:

  • float:left - 使用浮動塊元素的幻燈片彼此相鄰
  • display:block - 顯示塊元素的鏈接,讓整體變為可點擊鏈接區域(不只是文本),它允許我們指定寬度
  • width:60px - 塊元素默認情況下是最大寬度。我們要指定一個60像素的寬度

九、水平導航條實例

創建一個水平導航條,在鼠標移動到選項后修改背景顏色。

ul {
    list-style-type: none;
    margin: 0;
    padding: 0;
    overflow: hidden;
    background-color: #333;
}
 
li {
    float: left;
}
 
li a {
    display: block;
    color: white;
    text-align: center;
    padding: 14px 16px;
    text-decoration: none;
}
 
/*鼠標移動到選項上修改背景顏色 */
li a:hover {
    background-color: #111;
}

1,鏈接右對齊

在點擊了選項后,我們可以添加 "active" 類來標准哪個選項被選中:

.active {
    background-color: #4CAF50;
}

2,鏈接右對齊

將導航條最右邊的選項設置右對齊 (float:right;):

<ul>
  <li><a href="#home">主頁</a></li>
  <li><a href="#news">新聞</a></li>
  <li><a href="#contact">聯系</a></li>
  <li style="float:right"><a class="active" href="#about">關於</a></li>
</ul>

3,添加分割線

<li> 通過 border-right 樣式來添加分割線:

/* 除了最后一個選項(last-child) 其他的都添加分割線 */
li {
    border-right: 1px solid #bbb;
}
 
li:last-child {
    border-right: none;
}

4,固定導航條

可以設置頁面的導航條固定在頭部或者底部:

(1)固定在頭部

ul {
    position: fixed;
    top: 0;
    width: 100%;
}

(2)固定在底部

ul {
    position: fixed;
    bottom: 0;
    width: 100%;
}

注意: 該實例可以在移動設備上使用

十、灰色水平導航條

/*固定在底部*/
ul {
    border: 1px solid #e7e7e7;
    background-color: #f3f3f3;
}
 
li a {
    color: #666;
}

十一、示例

(1)示例1:

響應式頂部導航:如何使用 CSS3 媒體查詢來創建一個響應式導航。

html代碼:

<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
</head>
<body>

<ul class="sidenav">
  <li><a class="active" href="#home">主頁</a></li>
  <li><a href="#news">新聞</a></li>
  <li><a href="#contact">聯系</a></li>
  <li><a href="#about">關於</a></li>
</ul>

<div class="content">
  <h2>響應式邊欄導航實例</h2>
  <p>該實例在屏幕寬度小於 900px 時導航欄為頂部水平導航欄,如果大於 900px 導航欄會在左邊,且是固定的。</p>
  <p>如果屏幕寬度小於 400px 會變為垂直導航欄。</p>
  <h3>重置瀏覽器窗口大小,查看效果。</h3>
</div>

</body>
</html>

css代碼:

body {margin: 0;}

ul.sidenav {
    list-style-type: none;
    margin: 0;
    padding: 0;
    width: 25%;
    background-color: #f1f1f1;
    position: fixed;
    height: 100%;
    overflow: auto;
}

ul.sidenav li a {
    display: block;
    color: #000;
    padding: 8px 16px;
    text-decoration: none;
}
 
ul.sidenav li a.active {
    background-color: #4CAF50;
    color: white;
}

ul.sidenav li a:hover:not(.active) {
    background-color: #555;
    color: white;
}

div.content {
    margin-left: 25%;
    padding: 1px 16px;
    height: 1000px;
}

@media screen and (max-width: 900px) {
    ul.sidenav {
        width: 100%;
        height: auto;
        position: relative;
    }
    ul.sidenav li a {
        float: left;
        padding: 15px;
    }
    div.content {margin-left: 0;}
}

@media screen and (max-width: 400px) {
    ul.sidenav li a {
        text-align: center;
        float: none;
    }
}

效果:

(2)示例2:

響應式邊欄導航:如何使用 CSS3 媒體查詢來創建一個邊欄導航。

html代碼:

<!DOCTYPE html>
<html>
<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0">
</head>
<body>

<ul class="topnav">
  <li><a class="active" href="#home">主頁</a></li>
  <li><a href="#news">新聞</a></li>
  <li><a href="#contact">聯系</a></li>
  <li class="right"><a href="#about">關於</a></li>
</ul>

<div style="padding:0 16px;">
  <h2>響應式導航欄實例</h2>
  <p>在屏幕寬度小於 600px 會重置導航欄。</p>
  <h4>重置瀏覽器窗口大小,查看效果。</h4>
</div>

</body>
</html>

css代碼:

body {margin: 0;}

ul.topnav {
    list-style-type: none;
    margin: 0;
    padding: 0;
    overflow: hidden;
    background-color: #333;
}

ul.topnav li {float: left;}

ul.topnav li a {
    display: block;
    color: white;
    text-align: center;
    padding: 14px 16px;
    text-decoration: none;
}

ul.topnav li a:hover:not(.active) {background-color: #111;}

ul.topnav li a.active {background-color: #4CAF50;}

ul.topnav li.right {float: right;}

@media screen and (max-width: 600px){
    ul.topnav li.right, 
    ul.topnav li {float: none;}
}

效果:

(3)示例3:

導航下拉菜單:在導航條內部設置下拉菜單

html代碼:

<!DOCTYPE html>
<html>
<head>
<title>下拉菜單實例|菜鳥教程(runoob.com)</title>
<meta charset="utf-8">
<style>
  ul{
    list-style-type:none;
    margin:0;
    padding:0;
    overflow:hidden;
    background-color:#333;
  }
  
  li{
    float:left;
  }
  
  li a, .dropbtn
  {
    display:inline-block;
    color:white;
    text-align:center;
    padding:14px 16px;
    text-decoration:none;
  }
  
  li a:hover, .dropdown:hover, .dropbtn
  {
    background-color:#111;
  }
  
  .dropdown
  {
    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: #f1f1f1}
  
  .dropdown:hover .dropdown-content
  {
    display:block;
  }
  
  </style>
</head>
<body>

<ul>
  <li><a class="active" href="#home">主頁</a></li>
  <li><a href="#news">新聞</a></li>
  <div class="dropdown">
    <a href="#" class="dropbtn">下拉菜單</a>
    <div class="dropdown-content">
      <a href="#">鏈接 1</a>
      <a href="#">鏈接 2</a>
      <a href="#">鏈接 3</a>
    </div>
  </div>
</ul>

<h3>導航欄上的下拉菜單</h3>
<p>鼠標移動到 "下拉菜單" 鏈接先顯示下拉菜單。</p>

</body>
</html>

效果:

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM