- Bootstrap 4:Responsive Web Design
- Silvio Moreto Matt Lambert Benjamin Jakobus Jason Marah
- 626字
- 2021-07-09 18:54:45
Paying attention to your navigation
Bootstrap offers a very nice navigation bar to be placed at the top of website, or even in places where you want that behavior. Let's change our header section to make it our navigation bar. It will stick to the top of the web page, working as a navigation menu.
First of all, let's use a <nav>
element and add to it the .navbar
and .navbar-default
classes, which are required for the component, and the .navbar-fixed-top
class to fix the element at the top. Replace the <header>
HTML section with the following code:
<nav class="navbar navbar-default navbar-fixed-top"> <div class="navbar-header"> <a class="navbar-brand" href="landing_page.html">Company name</a> </div> <div class="navbar-right"> <ul class="nav navbar-nav"> <li><a href="#about">About</a></li> <li><a href="#features">Features</a></li> <li><a href="#pricing">Pricing</a></li> <li><a href="contact.html">Contact</a></li> </ul> </div> </nav>
As was mentioned, the .navbar
and .navbar-default
classes are required for the navigation component. For the Company name link, we added a class, .navbar-brand
, which has the purpose of branding the heading with an appropriate font size and padding.
Then, we created a <div>
tag using the .navbar-right
class to provide a set padding CSS rules and place the list to the right to appear the same way as was before. For the CSS, just add the following rule to create a padding to the <body>
of your page:
body { padding-top: 3.6em; } #nav-menu { margin-right: 1rem; }
The result of the navigation bar should be like what is presented in the following screenshot:

Until the navigation collapse
Try to resize the web page and you will see that for small viewports, the horizontal list placed in the navigation will stack vertically, as illustrated in the next screenshot. Fortunately, Bootstrap has the option to collapse the lists at the navigation bar. The procedure for doing this is pretty simple and we will do it now.

So, let's make the .nav-header
collapses and create a toggle
button to show or hide the list menu. Change the HTML to this:
<nav class="navbar navbar-default navbar-fixed-top"> <div class="navbar-header"> <a class="navbar-brand" href="landing_page.html">Company name</a> <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#nav-menu" aria-expanded="false"> <span class="sr-only">Toggle navigation</span> <span class="icon-bar"></span> <span class="icon-bar"></span> <span class="icon-bar"></span> </button> </div> <div id="nav-menu" class="collapse navbar-collapse navbar-right"> <ul class="nav navbar-nav"> <li><a href="#about">About</a></li> <li><a href="#features">Features</a></li> <li><a href="#pricing">Pricing</a></li> <li><a href="contact.html">Contact</a></li> </ul> </div> </nav>
The new code is in bold. First, we added a <button>
element to create our sandwich button (the one with three dashes). On data-target
, we must add the element that is the collapse target, #nav-menu
in our case.
Then, we must say which is the element to be collapsed in the small viewport, so for .navbar-right
, we added the .collapse.navbar-collapse
classes. The navigation bar should then appear like the one shown in the following screenshot. Hooray! Bootstrap has saved the day again!

Using different attachments
For this example, we fixed the navigation bar to the top of our web page, although we can use different attachments. For instance, we can attach the navigation bar to the bottom using the .navbar-fixed-bottom
class.
The bar can also be static. For that, use the .navbar-static-*
class, where the asterisk can mean top
or bottom
. If you are using the static navigation bars, you must place a container (static or fluid) right in the next level of the component:
<nav class="navbar navbar-default navbar-static-top"> <div class="container"> … </div> </nav>
Coloring the bar
You can also change the color of the navigation bar. Bootstrap version 3 offers an inverted set of colors. To do so, add the .navbar-inverse
class to the <nav>
element, as follows:
<nav class="navbar navbar-inverse"> … </nav>
In version 4, they added other color options. So if the background of your navigation bar has a dark color, add the .navbar-dark
class to make the text and other elements white. If the background has a light color, use the .navbar-light
class to get the opposite result.
For the background color, you can pass a class called .bg-*
, where the asterisk means a set of colors from Bootstrap. These are default
, primary
, info
, success
, warning
, or danger
:
<nav class="navbar navbar-dark bg-danger"> … </nav>
- Learn Type:Driven Development
- 構(gòu)建移動(dòng)網(wǎng)站與APP:HTML 5移動(dòng)開(kāi)發(fā)入門(mén)與實(shí)戰(zhàn)(跨平臺(tái)移動(dòng)開(kāi)發(fā)叢書(shū))
- Instant Zepto.js
- PyTorch Artificial Intelligence Fundamentals
- NumPy Essentials
- 深入淺出PostgreSQL
- Android系統(tǒng)原理及開(kāi)發(fā)要點(diǎn)詳解
- Learning Apache Karaf
- 現(xiàn)代C:概念剖析和編程實(shí)踐
- NGUI for Unity
- Mastering Embedded Linux Programming
- Three.js權(quán)威指南:在網(wǎng)頁(yè)上創(chuàng)建3D圖形和動(dòng)畫(huà)的方法與實(shí)踐(原書(shū)第4版)
- 交互設(shè)計(jì)師成長(zhǎng)手冊(cè):從零開(kāi)始學(xué)交互
- Mastering Bootstrap 4
- Enterprise Application Architecture with .NET Core