使用标准<nav> & <ul>
时,很容易创建显示在单行上的导航:
桌面:http: //jsfiddle.net/Baumr/Be9ma/1/
由于这是用于响应式布局,因此在较小的显示器上,导航将收缩为 3 列(甚至可能是 2 列),并带有媒体查询(代码中未包含):
手机:http: //jsfiddle.net/Baumr/Be9ma/
但它在美学上没有间隔:
由于nav li
元素的宽度是 33.3333%,所以间距是混乱的——一些导航项很长,一些很短。但是间距不是流动的。
如何将每列调整为仅与最宽元素 + 填充/边距一样宽?也就是说,没有分离或嵌套ul
输出——这会破坏语义,并且在宽显示器上查看时。
这是简单的 HTML:
<nav>
<ul>
<li>Home</li>
<li>Very Long Link</li>
<li>Blog</li>
<li>About</li>
<li>Also Long Link</li>
<li>Email</li>
</ul>
</nav>
这是相关的CSS:
nav {
clear: both;
background: pink;
}
nav ul {
padding: 20px 10px 0 30px;
margin: 0;
overflow: hidden;
font-size: 16px;
}
nav li {
font-variant: small-caps;
text-decoration: underline;
list-style: none;
display: block;
float: left;
padding: 0 0 30px 0;
margin: 0;
width: 33.33333%;
float: left;
}
很想听听你的想法。先感谢您!
PS 我想强调跨浏览器的兼容性和语义。