Como faço para converter uma lista com links gráficos em uma lista embutida?

StackOverflow https://stackoverflow.com/questions/45163

  •  09-06-2019
  •  | 
  •  

Pergunta

Dado este HTML:

<ul id="topnav">
    <li id="topnav_galleries"><a href="#">Galleries</a></li>
    <li id="topnav_information"><a href="#">Information</a></li>
</ul>

E este CSS:

#topnav_galleries a, #topnav_information a {
    background-repeat: no-repeat;
    text-indent: -9000px;
    padding: 0;
    margin: 0 0;
    overflow: hidden;
    height: 46px;
    width: 136px;
    display: block;
}
#topnav { list-style-type: none; }
#topnav_galleries a { background-image: url('image1.jpg'); }
#topnav_information a { background-image: url('image2.jpg'); }

Como eu faria para virar o topnav lista em uma lista embutida?

Foi útil?

Solução

Experimente isto:

#topnav {
    overflow:hidden;
}
#topnav li {
    float:left;
}

E para o IE você precisará adicionar o seguinte:

#topnav {
    zoom:1;
}

Caso contrário, suas tags <li> flutuantes sairão do <ul> que o contém.

Outras dicas

Outra abordagem seria usar display: inline-block para li é:

#topnav li {
    display: inline-block;
}

Uma alternativa para flutuar os elementos à esquerda é esta:

#topnav li {
    display: inline;
}
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top