Quiero alinear elementos a la derecha de un menú de navegación superior, es un menú de posición fija, así que alinee el texto: derecha; no funciona

Lo que intenté hasta ahora: para la pantalla normal (computadora / laptop) intenté hacer algo como:

.navbar {
     position: fixed;
     width: 100%;
}

.navbar .menu_items {
     margin-left: 75% /*this leaves a 25% on the right for the menu items *%
} 

Esto funciona bien para una visualización normal, pero al minimizar la ventana del navegador, los elementos del menú se apilan en el 25% restante del ancho.

Pensé en hacer consultas de medios para diferentes tamaños de pantalla que no es eficiente.

Aquí están mis códigos:

Css

body, header{
  margin: 0;
  padding: 0;
}

.navbar {
  position: fixed;
  background-color: rgb(90,80,50);
  width: 100%;
  border-bottom: 2px solid rgb(70,60,30);
  box-shadow: 2px 2px 3px 1px rgb(70,60,30);

}

.menu-items {
  margin: 0;
  padding: 1em 1em 1em 0em;
}

.navbar .menu-items li {
  padding: inherit;
  font-size: 1.5em;
  display: inline;
}

.navbar .menu-items li a:link,
.navbar .menu-items li a:visited {
  padding: inherit;
  padding-left: 0.5em; 
  text-decoration: none;
  color: #eee;
}

.navbar .menu-items li a:hover {
  background-color: rgb(70,60,30)
}

Html

<!DOCTYPE html>
<html>
</html> 

<header>
  <nav class="navbar">
    <ul class="menu-items">
      <li><a href="#">Home</a></li>
      <li><a href="#">About</a></li>
      <li><a href="#">Contact</a></li>
    </ul>
  </nav>  
</header>

<div class="body">
   <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr> <hr> <br> <hr> <br>  <hr>
</div>
</html>
0
Ibrahim Sharaf 6 oct. 2019 a las 22:57

4 respuestas

La mejor respuesta

Puede lograr esto configurando el navegador en display: flex y configurando el ul en margin-left: auto. Cuando los artículos están en un contexto flexible, el margen automático en cualquier lado los empujará al final del cuadro.

.navbar{
   display: flex;
}
.navbar > .menu-items{
   margin-left: auto;
}

body,
header {
  margin: 0;
  padding: 0;
}

.navbar {
  position: fixed;
  background-color: rgb(90, 80, 50);
  width: 100%;
  border-bottom: 2px solid rgb(70, 60, 30);
  box-shadow: 2px 2px 3px 1px rgb(70, 60, 30);
}

.menu-items {
  margin: 0;
  padding: 1em 1em 1em 0em;
}

.navbar .menu-items li {
  padding: inherit;
  font-size: 1.5em;
  display: inline;
}

.navbar .menu-items li a:link,
.navbar .menu-items li a:visited {
  padding: inherit;
  padding-left: 0.5em;
  text-decoration: none;
  color: #eee;
}

.navbar .menu-items li a:hover {
  background-color: rgb(70, 60, 30)
}
<header>
  <nav class="navbar">
    <ul class="menu-items">
      <li><a href="#">Home</a></li>
      <li><a href="#">About</a></li>
      <li><a href="#">Contact</a></li>
    </ul>
  </nav>


</header>

<div class="body">
  <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
  <hr> <br>
  <hr> <br>
  <hr>
</div>
0
symlink 6 oct. 2019 a las 22:04

Puedes usar este código

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
    <link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/css/bootstrap.min.css" integrity="sha384-ggOyR0iXCbMQv3Xipma34MD+dH/1fQ784/j6cY/iJTQUOhcWr7x9JvoRxT2MZw1T" crossorigin="anonymous">
    <title>Hello, world!</title>
    <style type="text/css">
        body,
        header {
            margin: 0;
            padding: 0;
        }
        .navbar-light .navbar-brand {
            color: #ffffff!important;
            margin-left: 30px;
        }
        .navbar {
            position: fixed;
            background-color: rgb(90, 80, 50)!important;
            width: 100%;
            border-bottom: 2px solid rgb(70, 60, 30);
            box-shadow: 2px 2px 3px 1px rgb(70, 60, 30);
            padding: 20px 0;
        }
        .navbar .navbar-nav {
            margin: 0;
            padding: 0;
        }
        .navbar .navbar-nav li {
            padding: inherit;
            font-size: 1.5em;
            display: inline;
        }
        .navbar .navbar-nav li a:link,
        .navbar .navbar-nav li a:visited {
            padding: 10px 45px;
            text-decoration: none;
            color: #eeeeee!important;
        }
        .navbar .navbar-nav li a:hover {
            background-color: rgb(70, 60, 30)
        }
        .navbar-light .navbar-toggler {
            color: #fff !important;
            border-color: #fff !important;
            margin-right: 30px;
        }
    </style>
</head>
<body>
    <nav class="navbar navbar-expand-lg navbar-light bg-light">
        <a class="navbar-brand" href="#">Navbar</a>
        <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
            <span class="navbar-toggler-icon"></span>
        </button>
        <div class="collapse navbar-collapse" id="navbarSupportedContent">
            <ul class="navbar-nav ml-auto">
                <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="#">About</a>
                </li>
                <li class="nav-item">
                    <a class="nav-link" href="#">Contact</a>
                </li>
            </ul>
        </div>
    </nav>
    <div class="body">
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
        <hr>
        <br>
        <hr>
        <br>
        <hr>
    </div>
    <script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.7/umd/popper.min.js" integrity="sha384-UO2eT0CpHqdSJQ6hJty5KVphtPhzWj9WO1clHTMGa3JDZwrnQq4sF86dIHNDz0W1" crossorigin="anonymous"></script>
    <script src="https://stackpath.bootstrapcdn.com/bootstrap/4.3.1/js/bootstrap.min.js" integrity="sha384-JjSmVgyd0p3pXB1rRibZUAYoIIy6OrQ6VrjIEaFf/nJGzIxFDsf4x0xIM+B07jRM" crossorigin="anonymous"></script>
</body>
</html>
0
Piyush Teraiya 7 oct. 2019 a las 06:49

En css da la flotadora: propiedad correcta

Aquí está el código

.menu-items { float: right; }

0
Bhuvanesh kumar 7 oct. 2019 a las 07:01

Sintaxis adecuada para flex:

/*CSS*/

#parent {
  display: flex;
  flex-direction: row;/*not required, default value is row*/
  justify-content: flex-end;
}

Pero también puedes usar float: right; en el elemento

0
sao 6 oct. 2019 a las 21:48