Altezza automatica della barra di navigazione CSS
-
22-12-2019 - |
Domanda
Voglio impostare il secondo livello di navigatore da essere altezza automatica, passare a una nuova riga quando è troppo lungo.
HTML:
<ul id="menu">
<li><a href="">About Us</a>
<ul>
<li><a href="">Introduction</a></li>
<li><a href="">Orgaizational Structure</a></li>
<li><a href="">Mission&Vision</a></li>
</ul>
</li>
</ul>
.
CSS:
* {
padding: 0;
margin: 0;
}
#menu {
list-style: none;
font-size: 0.8em;
border-radius: 5px;
-webkit-box-shadow: 0 5px 10px 0 #cccccc;
box-shadow: 0 2px 5px 0 #aaa;
background: #dddddd;
height: 40px;
width: 800px;
float: left;
}
#menu li {
display: block;
position: relative;
float: left;
}
#menu li ul {
display: none;
}
#menu li a {
display: block;
text-decoration: none;
padding: 12px 15px;
margin-left: 1px;
white-space: nowrap;
}
#menu li:hover ul {
display: block;
position: absolute;
background: #dddddd;
border-radius: 5px;
-webkit-box-shadow: 0 5px 10px 0 #cccccc;
box-shadow: 0 2px 5px 0 #aaa;
width: 100px;
}
.
Eseguilo qui: http://jsfiddle.net/u72hm/
Soluzione
Non sono sicuro di cosa stai chiedendo, ma se vuoi che il tuo testo si avvolga su una nuova riga, modificare white-space:no-wrap;
in white-space:normal
per menu li a{...}
.
Altri suggerimenti
Mentre questa risposta non risponde tecnicamente alla domanda, ci sono alcune risorse eccellenti per il menu qui http://www.cssplay.co.uk/menus/ Spiegando perché vengono prese alcune decisioni CSS e per quali browser.
Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow