Bootstrap 4 导航栏
导航栏
导航栏一般放在页面的顶部:
基础导航栏
使用 Bootstrap,导航栏可以扩展或折叠,具体取决于屏幕大小。
我们可以使用 .navbar
类来创建一个标准的导航栏,后面紧跟: .navbar-expand-xxl|xl|lg|md|sm
类来创建响应式的导航栏 (大屏幕水平铺开,小屏幕垂直堆叠)。
导航栏上的选项可以使用 <ul>
元素 (或 <div>
) 并添加 class="navbar-nav"
类。 然后在 <li>
元素上添加 .nav-item
类,<a>
元素上使用 .nav-link
类:
实例
<!-- 在小屏幕上变为垂直的灰色水平导航栏 -->
<nav class="navbar navbar-expand-sm bg-light">
<!-- 链接 -->
<ul class="navbar-nav">
<li class="nav-item">
<a class="nav-link" href="#">Link 1</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link 2</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link 3</a>
</li>
</ul>
</nav>
亲自试一试 »
垂直导航栏
通过删除 .navbar-expand-xl|lg|md|sm
类来创建垂直导航栏:
实例
<!-- 垂直导航栏 -->
<nav class="navbar bg-light">
<!-- 链接 -->
<ul class="navbar-nav">
<li class="nav-item">
<a class="nav-link" href="#">链接 1</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">链接 2</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">链接 3</a>
</li>
</ul>
</nav>
亲自试一试 »
居中对齐的导航栏
通过添加 .justify-content-center
类来创建居中对齐的导航栏:
以下示例将在中、大和超大屏幕上居中显示导航栏。在小屏幕上,它将垂直显示并左对齐(因为 navbar-expand-sm 类):
不同颜色导航栏
可以使用以下类来创建不同颜色导航栏 (.bg-primary
,
.bg-success
, .bg-info
, .bg-warning
, .bg-danger
, .bg-secondary
, .bg-dark
和 .bg-light
)
提示: 对于暗色背景 .navbar-dark
需要设置文本颜色为浅色的,对于浅色背景 .navbar-light
需要设置文本颜色为深色的。
实例
<!-- 灰色配黑色文字 -->
<nav class="navbar navbar-expand-sm bg-light navbar-light">
<ul class="navbar-nav">
<li class="nav-item active">
<a class="nav-link" href="#">Active</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link disabled" href="#">Disabled</a>
</li>
</ul>
</nav>
<!-- 黑底白字 -->
<nav class="navbar navbar-expand-sm bg-dark navbar-dark">...</nav>
<!-- 蓝底白字 -->
<nav class="navbar navbar-expand-sm bg-primary navbar-dark">...</nav>
亲自试一试 »
激活和禁用状态: 可以在 <a>
元素上添加 .active
类来高亮显示选中的选项。 .disabled
类用于设置该链接是不可点击的。
品牌 / Logo
.navbar-brand
类用于高亮显示品牌/Logo:
实例
<nav class="navbar navbar-expand-sm bg-dark navbar-dark">
<a class="navbar-brand" href="#">Logo</a>
...
</nav>
亲自试一试 »
如果使用图片,可以使用 .navbar-brand
类来设置图片自适应导航栏。
实例
<nav class="navbar navbar-expand-sm bg-dark navbar-dark">
<a class="navbar-brand" href="#">
<img src="bird.jpg" alt="Logo" style="width:40px;">
</a>
...
</nav>
亲自试一试 »
折叠导航栏
通常,小屏幕上我们都会折叠导航栏,通过点击来显示导航选项。
要创建折叠导航栏,可以在按钮上添加 class="navbar-toggler", data-bs-toggle="collapse" and data-target="#thetarget"
类。然后在设置了
class="collapse navbar-collapse"
类的 div 上包裹导航内容(链接),
div 元素上的 id 匹配按钮 data-target
的上指定的 id。
实例
<nav class="navbar navbar-expand-md bg-dark
navbar-dark">
<!-- Brand -->
<a class="navbar-brand" href="#">Navbar</a>
<!-- 切换/折叠按钮 -->
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#collapsibleNavbar">
<span class="navbar-toggler-icon"></span>
</button>
<!-- Navbar links -->
<div class="collapse navbar-collapse" id="collapsibleNavbar">
<ul class="navbar-nav">
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
</ul>
</div>
</nav>
亲自试一试 »
提示: 您还可以删除 .navbar-expand-md
类以始终隐藏导航栏链接并显示切换按钮。
导航栏使用下拉菜单
导航栏上可以设置下拉菜单:
实例
<nav class="navbar navbar-expand-sm bg-dark navbar-dark">
<!-- Brand -->
<a class="navbar-brand" href="#">Logo</a>
<
br> <!-- 链接 -->
<ul class="navbar-nav">
<li class="nav-item">
<a class="nav-link" href="#">链接 1</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">链接 2</a>
</li>
<!-- Dropdown -->
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" id="navbardrop" data-toggle="dropdown">
Dropdown link
</a>
<div class="dropdown-menu">
<a class="dropdown-item" href="#">链接 1</a>
<a class="dropdown-item" href="#">链接 2</a>
<a class="dropdown-item" href="#">链接 3</a>
</div>
</li>
</ul>
</nav>
亲自试一试 »
导航栏的表单与按钮
导航栏的表单 <form> 元素使用 class="form-inline" 类来排版输入框与按钮:
实例
<nav class="navbar navbar-expand-sm bg-dark navbar-dark">
<form class="form-inline" action="/action_page.php">
<input class="form-control mr-sm-2" type="text" placeholder="Search">
<button class="btn btn-success" type="submit">Search</button>
</form>
</nav>
亲自试一试 »
您还可以使用其他输入类,例如 .input-group-prepend
或 .input-group-append
,在输入字段旁边附加图标或帮助文本。在 Bootstrap 输入一章中,您将了解有关这些类的更多信息。
实例
<nav class="navbar navbar-expand-sm bg-dark navbar-dark">
<form class="form-inline" action="/action_page.php">
<div class="input-group">
<div class="input-group-prepend">
<span class="input-group-text">@</span>
</div>
<input type="text" class="form-control" placeholder="Username">
</div>
</form>
</nav>
亲自试一试 »
导航栏文本
使用 .navbar-text
类来设置导航栏上非链接文本,可以保证水平对齐,颜色与内边距一样。
实例
<nav class="navbar navbar-expand-sm bg-dark navbar-dark">
<!-- 链接 -->
<ul class="navbar-nav">
<li class="nav-item">
<a class="nav-link" href="#">Link 1</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link 2</a>
</li>
</ul>
<!-- 导航栏文本-->
<span class="navbar-text">
Navbar text
</span>
</nav>
亲自试一试 »
固定导航栏
导航栏可以固定在头部或者底部。
固定导航栏在固定位置(顶部或底部)保持可见,与页面滚动无关。
使用 .fixed-top
类来实现导航栏的固定在顶部:
使用 .fixed-bottom
类用于设置导航栏固定在底部:
使用 .sticky-top
类使导航栏在滚动页面时固定/停留在页面顶部。注意:该类在 IE11 及更早版本中不起作用(将其视为 position:relative
)。