Aligning Content with Bootstrap Navbar on Mobile - html

I'm trying to create a very simple navbar on my page. I'm having trouble aligning content on the right of the navbar on mobile devices. I'm not trying to do any kind of collapsing or anything, I really just want the mobile navbar to look just like the desktop version.
My problem is on mobile devices, my right-aligned content is appearing beneath my header like so:
Mobile
Desktop
How I have it on Desktop right now is how I pretty much want it. I'd like to vertically align the buttons in the navbar too but I can take care of that part:
Here's my code:
<nav class="navbar navbar-default">
<div class="container-fluid">
<div class="navbar-header">
Favorite List
</div>
<ul class="nav navbar-nav navbar-right">
<li><button type="button" class="btn btn-default">Default</button></li>
<li><button type="button" class="btn btn-default">Default</button></li>
<li><button type="button" class="btn btn-default">Default</button></li>
</ul>
</div>
</nav>

I am fixed this.
use this css in your responsive for mobile view:
.container-fluid>.navbar-collapse, .container-fluid>.navbar-header, .container>.navbar-collapse, .container>.navbar-header {
margin-right: -15px;
margin-left: -15px;
display: inline-block;
float: left;
}
.navbar-nav {
margin: 7.5px -15px;
display: block;
float: right;
}
.nav>li {
position: relative;
display: inline-block;
}
.navbar-default .navbar-brand {
color: #777;
font-size: 15px;
}

Related

make navbar smaller on ipad

I do not know how I can make my navbar smaller on Ipad. As it is now, the navbar is hanging under my logo, and they should be on a row instead. I tried to set col-sm-12 because I thought everything in the div would take 12 col, but that does not work.
My website
Does anyone have an idea how I can do that?
HTML
<!-- begin nav -->
<nav class="navbar navbar-default" role="navigation">
<div class="container">
<div class="row">
<div class="col-sm-12 col-md-12">
<div class="navbar-header">
<button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
<span class="sr-only">Toggle navigation</span>
<i class="fa fa-reorder" style="padding-left: 4px; color: red;"></i>
</button>
<!-- begin logo in navigation -->
<a class="navbar-brand" href="https://<?php echo $_SERVER['HTTP_HOST']?>/index.php">
<img src="https://<?php echo $_SERVER['HTTP_HOST']?>/images/graphic/vouzalis-webdesign.png">
</a>
<!-- end logo in navigation -->
</div>
<div class="navbar-collapse collapse">
<ul class="nav nav-pills nav-main pull-right">
<!-- begin navigation items -->
<li>
Hjem
</li>
<li>
Kompetencer
</li>
<li>
Portfolio
</li>
<li>
Om Mig
</li>
<li>
Artikler
</li>
<li>
Kontakt
</li>
<!-- end navigation items -->
</ul>
</div>
</div>
</div>
</div>
</nav>
<!-- end nav -->
CSS
#media (max-width: 767px) {
/* Navigation */
.nav-main {
float: left!important;
}
.navbar-default .navbar-collapse,
.navbar-default .navbar-form {
border: none;
}
.nav-main li:first-child {
border-top: 1px dashed #444;
}
.navbar .dropdown-menu>li>a {
padding: 15px 20px;
}
.nav-pills>li {
float: none;
}
.nav-main {
width: 100%;
}
.navbar-brand {
padding: 0px 0px 0px 15px;
}
.fixednav .nav-main {
background: #171717;
margin-top: 14px;
}
.fixednav .nav-pills>li+li {
margin-left: 0px;
}
.dropdown-menu {
float: none;
position: static;
}
You need to define your tablet breakpoint in your css.
use another media query like #media (min-width: 768px) and (max-width: 1024px) {}
define the spacing and height that you want there and it will take affect.
EDIT
I see you have a breakpoint define for min-width: 769px and max-width 991px
You can keep that breakpoint if you wish but after looking at your site the real issue is that you have your wrapping container class set to 750px and margin 0 auto to center it.
The reason your nav bar is nesting under your name element is because this container is not wide enough to display both of them inline.
You can make the container larger say 100% width and adjust your margins or make your navigation buttons smaller.
or a combination of both.

how to affix a boxed navbar

Im using affix to make fixed my navbar when scroll.
But when scroll navbar is not working fine.
I use <header class="container"> to give a boxed look to header website, an center content.
if I would use header without container, header and menu would fit screen side-to-side. In this case the affixed navbar would work fine, fitting screen in the same way (taking 1391px width).
However Im using <header class="container">. And affixed navbar runs out of screen because is taking 1391px width too. Like if it were a side-to-side looked website. It does not adapt to container width.
Do you know how to solve it?
or
is it that bootstrap affix is desing just for stretched sites and no boxed sites?
This is my HTML for nav
<header class="container">
<nav id="custom-bootstrap-menu" class="navbar navbar-default" role="navigation" data-spy="affix" data-offset-top="222">
<div class="container-fluid">
<div class="navbar-header"><a class="navbar-brand" href="#">Home</a>
<button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-menubuilder"><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 class="collapse navbar-collapse navbar-menubuilder">
<ul class="nav navbar-nav navbar-left">
<li class="dropdown" class="dropdown">Nosotros <b class="caret"></b>
<ul class="dropdown-menu" role="menu">
<li>Misión, Visión y Objetivos
</li>
</ul>
</li>
</ul>
</div>
</div>
</nav>
</header>
and this is css
header{
border-top-width: 8px;
border-top-style: solid;
border-top-color: #888;
}
.affix {
position: fixed;
top: 0;
width: 100%;
z-index: 1;
right: 10%;
left: 10%;
}
.affix + .container-fluid {
padding-top: 70px;
}
Take a look here it is similar to what is happening to me. Make result screen smaller and bigger to see what happens
Without codes, I can only assume how your codes look like.
Using twitter bootstrap's navbar fixed navbar example, you need to change .navbar-fixed-top right and left values. Using 0 sets it from side to side.
#media (min-width: 768px) {
.navbar-fixed-top {
position: fixed;
right: auto;
left: auto;
}
}
After that, to make them all align, you would have to overwrite bootstrap's margins (for eg .navbar-right of you have that, etc).
See the fiddle: https://jsfiddle.net/jennift/o7utddud/2/
On a larger screen, you want the #nav.affix to follow the container size. Using 0 on left and right, uses the container as a guide, "stretching" it only as wide as the container.
On a smaller screen, the container now has the width of "auto" and with a fixed position it will stretch left to right. Using a padding of 20px (as used by the bootstrap css), you can realign it to the length of the header container.
#nav.affix {
position: fixed;
top: 0;
left:0;
right:0;
}
#media (max-width: 767px) { /*controls on smaller screen*/
#nav.affix {
left:20px; /*20px to follow bootstrap body padding */
right:20px;
}
}
Fiddle: http://jsfiddle.net/jennift/hnkutxsn/3/

Bootstrap responsive navbar

I am having an issue with bootstrap navbar in terms of responsiveness.
I used data-spy="affix" on my navbar to make sure it stays fixed at the top while scrolling down and it works perfectly.
The problem however is when I resize the window to mobile dimension.
When I resize to mobile dimension the right part of my navbar will appear out of bounds. Meaning I can't see the content because my navbar is too wide for the screen. However, when I scroll down and the affix effect takes over, my navbar scales to mobile screen and the content that went out of screen will align perfectly for the mobile screen and the entire navbar will be responsive.
Here is my HTML code for navbar:
<nav class="navbar navbar-inverse" data-spy="affix" data-offset-top="0">
<div class="navbar-header">
<div class="navbar-brand">
Title
</div>
</div>
<div class="collapse navbar-collapse">
<ul class="nav navbar-nav navbar-right">
<li>Page1</li>
<li>Page2</li>
<li>Blog</li>
<li>Contact</li>
<li>Shop</li>
<li><span class="glyphicon glyphicon-shopping-cart badge">5</span></li>
</ul>
</div>
</nav>
And this is my relevant CSS-code:
body {
font-size:large;
}
.glyphicon{
font-size: 95%;
}
.affix {
top:0px;
width:100%;
z-index:99999;
}
.affix + .container-fluid {
padding-top: 6.801%;
}
.navbar-header{
margin-left: 5% !important;
}
.navbar{
width:100% !important;
background-image:none;
background-color:black;
}
.navbar div a{
line-height:80px;
}
Also created a JSFiddle.
i have updated your codes in jsfiddle. can you please check now, and if you dont get that add bootstrap button to your navbar-header and i have a css code for you
#media (max-width:767px){
.navbar div a {
line-height: 20px;
}
.affix-top .collapse {
display:block !important;
}
}

Bootstrap "navbar-brand" causing "navbar-nav" items to shift right from centered position in nav bar?

I am trying to create a navigation bar that has the "brand" (LOGO) on the left side, and the actual navigation items in the center of the entire bar. I am using the default Bootstrap navbar as I just started to learn web development a week ago. This is what it looks like so far:
However, you can see the navigation items are slightly shifted to the right of the actual center of the page (The heading "This is the HOME page." is exactly centered within the page).
Here are parts of my code that I believe may be relevant:
html,
body {
height: 100%;
margin: 0;
padding: 0;
}
.container-fluid {
background-color: white;
border: none;
box-shadow: none;
}
.content {
padding-top: 65px;
width: 100%;
height: 100%;
}
.navbar .navbar-collapse {
text-align: center;
background-color: cyan;
}
.navbar .navbar-nav {
margin: 1%;
display: inline-block;
float: none;
vertical-align: center;
text-decoration: bold;
text-align: center;
}
.navbar-default {
background-color: white;
box-shadow: none;
text-align: center;
}
.navbar-header {
margin: 1%;
}
<!-- Navigation bar -->
<nav class="navbar navbar-default navbar-fixed-top">
<div class="container-fluid">
<!-- Brand and toggle get grouped for better mobile display -->
<div class="navbar-header">
<button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1" 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>
<a class="navbar-brand" href="index.html" id="logo">LOGO</a>
</div>
<!-- Collect the nav links, forms, and other content for toggling -->
<div class="collapse navbar-collapse">
<ul class="nav navbar-nav">
<li>Link 1</li>
<li>Link 2</li>
<li>Link 3</li>
<li>Link 4</li>
</ul>
</div>
<!-- /.navbar-collapse -->
</div>
<!-- /.container-fluid -->
</nav>
I am suspicious of the "navbar-brand" as it seems to interfere somehow when I try to change the text-align for ".navbar .navbar-collapse," (colored cyan just for ease of formatting) which I have set to "center" as other answers on StackOverflow have suggested.
For example, when I change the text-align to "left":
.navbar .navbar-collapse {
text-align: left;
background-color: cyan;
}
the navigation bar looks like this:
Changing the text-align to "right" pushes the navigation items all the way over to the right side of the cyan bar, as expected.
Thus, it appears that the navigation items are being centered between the "navbar-brand" and the right side of the bar rather than between the actual left and right sides of the entire bar.
Does anyone have any suggestions on how to make my navigation items accurately centered within the entire bar, so that they are in line with the heading "This is the HOME page." and not shifted to the right?
There are a few different ways to do this, and I guess it depends on what you are going to do further down the track, but the easiest thing is probably to take the .navbar-brand out of the document flow, so that the .navbar-nav ignores it when centering.
You can do this quite easily by adding something like this:
.navbar-brand {
position: absolute;
}
You can check it out over here: http://codepen.io/anon/pen/PNMBQx
Hope that helps, and good luck!

Header content disappearing when CSS applied for responsive layout (bootstrap file included in html)

I am setting a responsive layout for my personal website, which has worked in a simple example. However I am not getting the same results. It may have something to do with including the Bootstrap files in my html. Below is the html and css code for the responsive layout:
HTML:
<header>
<a href="/" id="logo">
<h1>Brian Weber</h1>
<h2>Engineer | Python Programmer</h2>
</a>
<!-- Navigation bar -->
<nav class="navbar navbar-default" role="navigation">
<div class="container-fluid">
<div class="navbar-header">
<button type="button" class="navbar-toggle" data-toggle="collapse" data-target="#myNavbar">
<span class="icon-bar"></span>
<span class="icon-bar"></span>
<span class="icon-bar"></span>
</button>
<!-- <a class="navbar-brand" href="#">Brian Weber</a>
<p>Engineer</p> -->
</div>
<div class="collapse navbar-collapse" id="myNavbar">
<ul class="nav navbar-nav">
<li class="active">Home</li>
<li>Portfolio</li>
<li>About</li>
<li>Resume</li>
<li>Contact</li>
</ul>
</div>
</div>
</header>
CSS:
#media screen and (min-width: 660px) {
/*********************************
HEADER
*********************************/
.navbar .navbar-default {
float: right;
background: none;
font-size: 1.125em;
margin-right: 5%;
text-align: right;
width: 45%;
}
#logo {
float: left;
margin-left: 5%;
text-align: left;
width: 45%;
}
#logo h1 {
font-size: 2.5em;
}
#logo h2 {
font-size: 1.7em;
margin-bottom: 20px;
}
header {
border-bottom: 5px solid #599a68;
margin-bottom: 60px;
}
}
When I check the code in a browser, the h1 and h2 text do not appear. However when I inspect the element there are placeholders for where the text should be. The text color is already set to black in the main.css. My question is how would I fix this problem so that the layout looks like the picture below? I am thinking maybe there is an issue with the bootstrap files where they are overriding the CSS code.
Correct format for header and navbar
h1 and h2 text disappearing
Add this in your style
#logo
{
z-index:1;
position:relative;
}
The z-index property specifies the stack order of an element.
An element with greater stack order is always in front of an element with a lower stack order. and in your style navbar-default hide the h1 and h2 that's why it's not looking
Make .navbar-default float right when in the larger views. It was covering up the left floating div that contained your name etc.
Add position:relative; and z-index for logo.
#logo {
float: left;
margin-left: 5%;
text-align: left;
width: 45%;
position: relative;
z-index: 1;
}