2014-07-13 23:33:54 -07:00
---
2015-08-14 22:45:55 -07:00
layout: docs
2014-10-27 04:52:48 -07:00
title: Navbar
2016-10-02 18:19:47 -07:00
description: Documentation and examples for Bootstrap's powerful, responsive navigation header.
2015-08-05 17:47:45 -07:00
group: components
2014-07-13 23:33:54 -07:00
---
2016-10-17 22:09:11 -07:00
The navbar is a wrapper that positions branding, navigation, and other elements into a concise header. It's easily extensible and thanks to our Collapse plugin, it can easily integrate responsive behaviors.
2014-07-13 23:33:54 -07:00
2015-05-29 01:58:52 -07:00
## Contents
* Will be replaced with the ToC, excluding the "Contents" header
{:toc}
2015-08-17 23:43:59 -07:00
## Basics
2014-10-27 04:49:24 -07:00
Here's what you need to know before getting started with the navbar:
2015-10-31 01:54:33 +01:00
- Navbars require a wrapping `.navbar` and a [color scheme ](#color-schemes ).
2014-10-27 04:49:24 -07:00
- Navbars and their contents are fluid by default. Use [optional containers ](#containers ) to limit their horizontal width.
2016-10-17 22:09:11 -07:00
- Use `.float-*-left` and `.float-*-right` to quickly align sub-components.
2014-11-30 20:17:45 -08:00
- Ensure accessibility by using a `<nav>` element or, if using a more generic element such as a `<div>` , add a `role="navigation"` to every navbar to explicitly identify it as a landmark region for users of assistive technologies.
2014-10-27 04:49:24 -07:00
2015-08-17 23:43:59 -07:00
## Supported content
2014-10-27 04:49:24 -07:00
2016-10-17 22:09:11 -07:00
Navbars come with built-in support for a handful of sub-components. Mix and match from the following as needed:
2014-10-27 04:49:24 -07:00
2015-08-17 23:43:59 -07:00
- `.navbar-brand` for your company, product, or project name
- `.navbar-nav` for a full-height and lightweight navigation (including support for dropdowns)
2016-10-04 02:55:59 +10:00
- `.navbar-toggler` for use with our collapse plugin and other [navigation toggling ](#collapsible-content ) behaviors.
2016-10-19 00:18:47 -07:00
- Inline forms with `.float-` utilities for form controls and components.
- `.navbar-text` for adding vertically centered strings of text.
2014-10-27 04:49:24 -07:00
2016-10-17 22:16:28 -07:00
Here's an example of all the sub-components included in a default, non-responsive light themed navbar. [See the responsive examples ](#collapsible-content ) for collapsing nav support.
2014-07-13 23:33:54 -07:00
2014-10-27 04:49:24 -07:00
{% example html %}
2015-08-18 00:46:29 -07:00
< nav class = "navbar navbar-light bg-faded" >
2015-08-17 23:43:59 -07:00
< a class = "navbar-brand" href = "#" > Navbar< / a >
< ul class = "nav navbar-nav" >
2014-07-13 23:33:54 -07:00
< li class = "nav-item active" >
2014-11-30 20:17:45 -08:00
< a class = "nav-link" href = "#" > Home < span class = "sr-only" > (current)< / span > < / a >
2014-07-13 23:33:54 -07:00
< / li >
< li class = "nav-item" >
2016-10-17 22:09:11 -07:00
< a class = "nav-link" href = "#" > Link< / a >
2014-07-13 23:33:54 -07:00
< / li >
< li class = "nav-item" >
2016-11-26 00:19:30 -08:00
< a class = "nav-link disabled" href = "#" > Disabled< / a >
2014-07-13 23:33:54 -07:00
< / li >
2016-10-17 22:09:11 -07:00
< li class = "nav-item dropdown" >
2016-10-17 23:37:02 -07:00
< a class = "nav-link dropdown-toggle" href = "http://example.com" id = "supportedContentDropdown" data-toggle = "dropdown" aria-haspopup = "true" aria-expanded = "false" > Dropdown< / a >
< div class = "dropdown-menu" aria-labelledby = "supportedContentDropdown" >
2016-10-17 22:09:11 -07:00
< a class = "dropdown-item" href = "#" > Action< / a >
< a class = "dropdown-item" href = "#" > Another action< / a >
< a class = "dropdown-item" href = "#" > Something else here< / a >
< / div >
2014-07-13 23:33:54 -07:00
< / li >
< / ul >
2016-10-31 21:27:56 -07:00
< form class = "form-inline float-right" >
2014-10-27 04:49:24 -07:00
< input class = "form-control" type = "text" placeholder = "Search" >
2016-01-06 01:32:39 -08:00
< button class = "btn btn-outline-success" type = "submit" > Search< / button >
2014-10-27 04:49:24 -07:00
< / form >
2014-11-30 20:17:45 -08:00
< / nav >
2014-10-27 04:49:24 -07:00
{% endexample %}
2015-12-06 22:34:06 -08:00
### Brand
2016-02-08 22:13:30 -08:00
The `.navbar-brand` can be applied to most elements, but an anchor works best as some elements might require utility classes or custom styles.
2015-12-06 22:34:06 -08:00
{% example html %}
2016-05-12 19:47:49 -07:00
<!-- As a link -->
2015-12-06 22:34:06 -08:00
< nav class = "navbar navbar-light bg-faded" >
< a class = "navbar-brand" href = "#" > Navbar< / a >
< / nav >
2016-05-12 19:47:49 -07:00
<!-- As a heading -->
2015-12-06 22:34:06 -08:00
< nav class = "navbar navbar-light bg-faded" >
2016-09-08 22:16:28 -07:00
< h1 class = "navbar-brand mb-0" > Navbar< / h1 >
2015-12-06 22:34:06 -08:00
< / nav >
{% endexample %}
2016-10-18 18:47:49 -07:00
Adding images to the `.navbar-brand` will likely always require custom styles or utilities to properly size. Here are some examples to demonstrate.
{% example html %}
<!-- Just an image -->
< nav class = "navbar navbar-light bg-faded" >
< a class = "navbar-brand" href = "#" >
2016-10-19 00:30:59 -07:00
< img src = "{{ site.baseurl }}/assets/brand/bootstrap-solid.svg" width = "30" height = "30" alt = "" >
2016-10-18 18:47:49 -07:00
< / a >
< / nav >
{% endexample %}
{% example html %}
<!-- Image and text -->
< nav class = "navbar navbar-light bg-faded" >
< a class = "navbar-brand" href = "#" >
2016-10-19 00:30:59 -07:00
< img src = "{{ site.baseurl }}/assets/brand/bootstrap-solid.svg" width = "30" height = "30" class = "d-inline-block align-top" alt = "" >
2016-10-18 18:47:49 -07:00
Bootstrap
< / a >
< / nav >
{% endexample %}
2015-12-06 22:34:06 -08:00
### Nav
Navbar navigation is similar to our regular nav options—use the `.nav` base class with a modifier to achieve a particular look. In this case you'll want `.nav.navbar-nav` .
2016-05-14 12:41:26 -07:00
Active states—with `.active` —to indicate the current page can be applied directly to `.nav-link` s or their immediate parent `.nav-item` s.
2015-12-06 22:34:06 -08:00
{% example html %}
< nav class = "navbar navbar-light bg-faded" >
< ul class = "nav navbar-nav" >
< li class = "nav-item active" >
< a class = "nav-link" href = "#" > Home < span class = "sr-only" > (current)< / span > < / a >
< / li >
< li class = "nav-item" >
< a class = "nav-link" href = "#" > Features< / a >
< / li >
< li class = "nav-item" >
< a class = "nav-link" href = "#" > Pricing< / a >
< / li >
< li class = "nav-item" >
2016-11-26 00:19:30 -08:00
< a class = "nav-link disabled" href = "#" > Disabled< / a >
2015-12-06 22:34:06 -08:00
< / li >
< / ul >
< / nav >
{% endexample %}
2015-12-08 00:36:42 -08:00
And because we use classes for our navs, you can avoid the list-based approach entirely if you like.
2015-12-06 22:34:06 -08:00
{% example html %}
< nav class = "navbar navbar-light bg-faded" >
< div class = "nav navbar-nav" >
< a class = "nav-item nav-link active" href = "#" > Home < span class = "sr-only" > (current)< / span > < / a >
< a class = "nav-item nav-link" href = "#" > Features< / a >
< a class = "nav-item nav-link" href = "#" > Pricing< / a >
2016-11-26 00:19:30 -08:00
< a class = "nav-item nav-link disabled" href = "#" > Disabled< / a >
2015-12-06 22:34:06 -08:00
< / div >
< / nav >
{% endexample %}
2016-05-13 08:19:16 -07:00
You may also utilize dropdowns in your navbar nav. Dropdown menus require a wrapping element for positioning, so be sure to use separate and nested elements for `.nav-item` and `.nav-link` as shown below.
{% example html %}
< nav class = "navbar navbar-light bg-faded" >
< ul class = "nav navbar-nav" >
< li class = "nav-item active" >
< a class = "nav-link" href = "#" > Home < span class = "sr-only" > (current)< / span > < / a >
< / li >
< li class = "nav-item" >
< a class = "nav-link" href = "#" > Features< / a >
< / li >
< li class = "nav-item" >
< a class = "nav-link" href = "#" > Pricing< / a >
< / li >
< li class = "nav-item dropdown" >
2016-10-16 20:45:12 -07:00
< a class = "nav-link dropdown-toggle" href = "http://example.com" id = "navbarDropdownMenuLink" data-toggle = "dropdown" aria-haspopup = "true" aria-expanded = "false" >
2016-05-13 08:19:16 -07:00
Dropdown link
< / a >
< div class = "dropdown-menu" aria-labelledby = "navbarDropdownMenuLink" >
< a class = "dropdown-item" href = "#" > Action< / a >
< a class = "dropdown-item" href = "#" > Another action< / a >
< a class = "dropdown-item" href = "#" > Something else here< / a >
< / div >
< / li >
< / ul >
< / nav >
{% endexample %}
2016-10-19 00:18:47 -07:00
### Forms
Place various form controls and components within a navbar with `.form-inline` . Align them with `.float-` utilities as needed.
{% example html %}
< nav class = "navbar navbar-light bg-faded" >
2016-10-31 21:27:56 -07:00
< form class = "form-inline float-left" >
2016-10-19 00:18:47 -07:00
< input class = "form-control" type = "text" placeholder = "Search" >
< button class = "btn btn-outline-success" type = "submit" > Search< / button >
< / form >
< / nav >
{% endexample %}
Input groups work, too:
{% example html %}
< nav class = "navbar navbar-light bg-faded" >
2016-10-31 21:27:56 -07:00
< form class = "form-inline float-left" >
2016-10-19 00:18:47 -07:00
< div class = "input-group" >
< span class = "input-group-addon" id = "basic-addon1" > @< / span >
< input type = "text" class = "form-control" placeholder = "Username" aria-describedby = "basic-addon1" >
< / div >
< / form >
< / nav >
{% endexample %}
Various buttons are supported as part of these navbar forms, too. This is also a great reminder that vertical alignment utilites can be used to align different sized elements.
{% example html %}
< nav class = "navbar navbar-light bg-faded" >
2016-10-31 21:27:56 -07:00
< form class = "form-inline float-left" >
2016-10-19 00:18:47 -07:00
< button class = "btn btn-outline-success" type = "button" > Main button< / button >
< button class = "btn btn-sm align-middle btn-outline-secondary" type = "button" > Smaller button< / button >
< / form >
< / nav >
{% endexample %}
2016-05-15 12:29:56 -07:00
### Text
Navbars may contain bits of text with the help of `.navbar-text` . This class adjusts vertical alignment and horizontal spacing for strings of text.
{% example html %}
< nav class = "navbar navbar-light bg-faded" >
2016-05-15 12:37:47 -07:00
< span class = "navbar-text" >
Navbar text with an inline element
< / span >
2016-05-15 12:29:56 -07:00
< / nav >
{% endexample %}
2016-05-15 12:37:47 -07:00
Using our utility classes, you can change the alignment and appearance of your navbar text.
2016-05-15 12:29:56 -07:00
{% example html %}
< nav class = "navbar navbar-light bg-faded" >
2016-10-31 21:27:56 -07:00
< span class = "navbar-text float-right text-muted" >
2016-05-15 12:37:47 -07:00
Muted navbar text that's floated right
< / span >
2016-05-15 12:29:56 -07:00
< / nav >
{% endexample %}
2016-05-15 12:37:47 -07:00
Similarly, you can use utility classes to align navbar text to other navbar elements like the brand and navigation (which are automatically floated already).
{% example html %}
< nav class = "navbar navbar-light bg-faded" >
< a class = "navbar-brand" href = "#" > Navbar< / a >
2016-10-31 21:27:56 -07:00
< span class = "navbar-text float-left" >
2016-05-15 12:37:47 -07:00
Navbar text that's floated left
< / span >
< / nav >
{% endexample %}
2015-12-06 22:34:06 -08:00
2015-08-18 00:46:29 -07:00
## Color schemes
2014-10-27 04:49:24 -07:00
2015-08-18 00:46:29 -07:00
Theming the navbar has never been easier thanks to the combination of a simple link color modifier class and `background-color` utilities. Put another way, you specify light or dark and apply a background color.
2014-07-13 23:33:54 -07:00
2015-08-18 00:46:29 -07:00
Here are some examples to show what we mean.
< div class = "bd-example" >
< nav class = "navbar navbar-dark bg-inverse" >
< a class = "navbar-brand" href = "#" > Navbar< / a >
< ul class = "nav navbar-nav" >
< li class = "nav-item active" >
< a class = "nav-link" href = "#" > Home < span class = "sr-only" > (current)< / span > < / a >
< / li >
< li class = "nav-item" >
< a class = "nav-link" href = "#" > Features< / a >
< / li >
< li class = "nav-item" >
< a class = "nav-link" href = "#" > Pricing< / a >
< / li >
< li class = "nav-item" >
< a class = "nav-link" href = "#" > About< / a >
< / li >
< / ul >
2016-10-31 21:27:56 -07:00
< form class = "form-inline float-right" >
2015-08-18 00:46:29 -07:00
< input class = "form-control" type = "text" placeholder = "Search" >
2016-01-06 01:32:39 -08:00
< button class = "btn btn-outline-info" type = "submit" > Search< / button >
2015-08-18 00:46:29 -07:00
< / form >
< / nav >
< nav class = "navbar navbar-dark bg-primary" >
< a class = "navbar-brand" href = "#" > Navbar< / a >
< ul class = "nav navbar-nav" >
< li class = "nav-item active" >
< a class = "nav-link" href = "#" > Home < span class = "sr-only" > (current)< / span > < / a >
< / li >
< li class = "nav-item" >
< a class = "nav-link" href = "#" > Features< / a >
< / li >
< li class = "nav-item" >
< a class = "nav-link" href = "#" > Pricing< / a >
< / li >
< li class = "nav-item" >
< a class = "nav-link" href = "#" > About< / a >
< / li >
< / ul >
2016-10-31 21:27:56 -07:00
< form class = "form-inline float-right" >
2015-08-18 00:46:29 -07:00
< input class = "form-control" type = "text" placeholder = "Search" >
2016-01-06 01:32:39 -08:00
< button class = "btn btn-outline-secondary" type = "submit" > Search< / button >
2015-08-18 00:46:29 -07:00
< / form >
< / nav >
< nav class = "navbar navbar-light" style = "background-color: #e3f2fd ;" >
< a class = "navbar-brand" href = "#" > Navbar< / a >
< ul class = "nav navbar-nav" >
< li class = "nav-item active" >
< a class = "nav-link" href = "#" > Home < span class = "sr-only" > (current)< / span > < / a >
< / li >
< li class = "nav-item" >
< a class = "nav-link" href = "#" > Features< / a >
< / li >
< li class = "nav-item" >
< a class = "nav-link" href = "#" > Pricing< / a >
< / li >
< li class = "nav-item" >
< a class = "nav-link" href = "#" > About< / a >
< / li >
< / ul >
2016-10-31 21:27:56 -07:00
< form class = "form-inline float-right" >
2015-08-18 00:46:29 -07:00
< input class = "form-control" type = "text" placeholder = "Search" >
2016-01-06 01:32:39 -08:00
< button class = "btn btn-outline-primary" type = "submit" > Search< / button >
2015-08-18 00:46:29 -07:00
< / form >
< / nav >
< / div >
{% highlight html %}
< nav class = "navbar navbar-dark bg-inverse" >
<!-- Navbar content -->
2014-11-30 20:17:45 -08:00
< / nav >
2015-08-18 00:46:29 -07:00
< nav class = "navbar navbar-dark bg-primary" >
<!-- Navbar content -->
< / nav >
< nav class = "navbar navbar-light" style = "background-color: #e3f2fd ;" >
<!-- Navbar content -->
< / nav >
{% endhighlight %}
2014-07-13 23:33:54 -07:00
2015-08-17 23:43:59 -07:00
## Containers
2015-06-22 16:30:52 -07:00
2015-12-06 22:47:23 -08:00
Although it's not required, you can wrap a navbar in a `.container` to center it on a page or add one within to only center the contents of a [fixed or static top navbar ](#placement ).
2015-04-18 18:12:10 -07:00
2015-08-17 23:43:59 -07:00
{% example html %}
< div class = "container" >
2015-08-18 00:46:29 -07:00
< nav class = "navbar navbar-light bg-faded" >
2015-08-17 23:43:59 -07:00
< a class = "navbar-brand" href = "#" > Navbar< / a >
2015-06-22 23:24:55 -07:00
< / nav >
< / div >
2015-08-17 23:43:59 -07:00
{% endexample %}
2015-06-22 23:24:55 -07:00
2015-08-17 23:43:59 -07:00
{% example html %}
2015-08-18 00:46:29 -07:00
< nav class = "navbar navbar-light bg-faded" >
2015-08-17 23:43:59 -07:00
< div class = "container" >
< a class = "navbar-brand" href = "#" > Navbar< / a >
< / div >
2015-04-18 18:12:10 -07:00
< / nav >
2015-08-17 23:43:59 -07:00
{% endexample %}
2015-04-18 18:12:10 -07:00
2015-08-18 01:18:21 -07:00
## Placement
2015-09-05 20:58:28 -07:00
Navbars can be statically placed (their default behavior), static without rounded corners, or fixed to the top or bottom of the viewport.
{% example html %}
< nav class = "navbar navbar-full navbar-light bg-faded" >
< a class = "navbar-brand" href = "#" > Full width< / a >
< / nav >
{% endexample %}
2015-08-18 01:18:21 -07:00
{% example html %}
< nav class = "navbar navbar-fixed-top navbar-light bg-faded" >
< a class = "navbar-brand" href = "#" > Fixed top< / a >
< / nav >
{% endexample %}
{% example html %}
< nav class = "navbar navbar-fixed-bottom navbar-light bg-faded" >
< a class = "navbar-brand" href = "#" > Fixed bottom< / a >
< / nav >
{% endexample %}
2015-08-17 23:43:59 -07:00
## Collapsible content
2014-07-13 23:33:54 -07:00
2014-11-30 20:17:45 -08:00
Our collapse plugin allows you to use a `<button>` or `<a>` to toggle hidden content.
2014-10-27 04:49:24 -07:00
{% example html %}
2015-08-18 00:46:29 -07:00
< nav class = "navbar navbar-light bg-faded" >
2016-07-08 09:54:53 +01:00
< button class = "navbar-toggler" type = "button" data-toggle = "collapse" data-target = " #exCollapsingNavbar " aria-controls = "exCollapsingNavbar" aria-expanded = "false" aria-label = "Toggle navigation" ></ button >
2015-12-24 18:10:37 +00:00
< div class = "collapse" id = "exCollapsingNavbar" >
2016-10-09 15:04:32 -07:00
< div class = "bg-inverse text-muted p-1" >
2015-12-24 18:10:37 +00:00
< h4 > Collapsed content< / h4 >
< span class = "text-muted" > Toggleable via the navbar brand.< / span >
< / div >
< / div >
2014-11-30 20:17:45 -08:00
< / nav >
2014-10-27 04:49:24 -07:00
{% endexample %}
2015-04-16 18:50:32 -07:00
For more complex navbar patterns, like those used in Bootstrap v3, use the `.navbar-toggleable-*` classes in conjunction with the `.navbar-toggler` . These classes override our responsive utilities to show navigation only when content is meant to be shown.
{% example html %}
2015-08-18 00:46:29 -07:00
< nav class = "navbar navbar-light bg-faded" >
2016-10-17 23:37:02 -07:00
< button class = "navbar-toggler hidden-lg-up" type = "button" data-toggle = "collapse" data-target = " #navbarResponsive " aria-controls = "navbarResponsive" aria-expanded = "false" aria-label = "Toggle navigation" ></ button >
2016-10-17 22:09:11 -07:00
< div class = "collapse navbar-toggleable-md" id = "navbarResponsive" >
< a class = "navbar-brand" href = "#" > Navbar< / a >
2015-08-17 23:43:59 -07:00
< ul class = "nav navbar-nav" >
< li class = "nav-item active" >
< a class = "nav-link" href = "#" > Home < span class = "sr-only" > (current)< / span > < / a >
< / li >
< li class = "nav-item" >
2016-10-17 22:09:11 -07:00
< a class = "nav-link" href = "#" > Link< / a >
2015-08-17 23:43:59 -07:00
< / li >
< li class = "nav-item" >
2016-10-17 22:09:11 -07:00
< a class = "nav-link" href = "#" > Link< / a >
2015-08-17 23:43:59 -07:00
< / li >
2016-10-17 22:09:11 -07:00
< li class = "nav-item dropdown" >
2016-10-17 23:45:25 -07:00
< a class = "nav-link dropdown-toggle" href = "http://example.com" id = "responsiveNavbarDropdown" data-toggle = "dropdown" aria-haspopup = "true" aria-expanded = "false" > Dropdown< / a >
< div class = "dropdown-menu" aria-labelledby = "responsiveNavbarDropdown" >
2016-10-17 22:09:11 -07:00
< a class = "dropdown-item" href = "#" > Action< / a >
< a class = "dropdown-item" href = "#" > Another action< / a >
< a class = "dropdown-item" href = "#" > Something else here< / a >
< / div >
2015-08-17 23:43:59 -07:00
< / li >
< / ul >
2016-10-17 22:09:11 -07:00
< form class = "form-inline float-lg-right" >
< input class = "form-control" type = "text" placeholder = "Search" >
< button class = "btn btn-outline-success" type = "submit" > Search< / button >
< / form >
2015-04-16 18:50:32 -07:00
< / div >
< / nav >
{% endexample %}