inline-block
我有很多不同的情况,当一个元素溢出到多行时,我希望包含一个菜单元素(通常是一个锚点)的 DIV就像垂直对齐元素一样。
我将使用一个示例案例来解释我想要实现的目标:
查看我的代码笔: http ://codepen.io/anon/pen/wBRpqJ?editors=110
输出:
发生的情况是,如果浏览器调整到更小的尺寸,那么最终的inline-block
Anchor 元素会下降到一个新行上,请参见屏幕截图(宽度约为 725px):
输出:
这本身很好,但我想做的是平均分割 DIV 中的元素,因为它在两行上,然后平均分布在两行上,因此大致合理,如果你将 codepen 调整为大约 500 像素宽,如果元素不能全部保持在一条线上,您会看到我希望它看起来如何。所以下面的图像是我想看看在父 DIV 元素中是否发生任何换行。
输出:
我意识到这个术语同样是一个不精确情况的精确术语,但是为了证明块中的元素是合理的,以便块中的每一行具有相同数量的元素 +/- 1(对于奇数计数)。
这是可以用 CSS 完成的吗?
PS> 这些元素的内容是动态的和多变的,任何解决方案有用的情况也将是动态的和多变的,因此专门针对这种情况的解决方案可能无济于事。
编辑:Flexbox 已被建议作为一种解决方案,我将如何使用 Flexbox 来达到预期的结果?
编辑 2:标准 - 菜单中的元素居中对齐,并且每个都是单独inline-block
的 s 。证明它们所做的一切是搞砸中心对齐并在 NAV 容器中的 Anchor 元素周围添加额外的间隔线。
编辑 3:我将把我的代码放在这里,用于 codepen 示例:
CSS:
.mainbox {
width:90%;
max-width:1200px;
min-width:400px;
margin:0.4em auto;
font-family: Arial, Helvetica, sans-serif;
font-size: 1em;
border: 1px solid #006;
}
nav {
background-color: rgba(204,204,204,0.4);
padding:5px 5px 0px 5px;
text-align:center;
position: absolute;
/* bottom increased from zero to make example clearer on codepen */
bottom:1em;
margin:auto;
width:90%;
/* width adjusted from 100% for codepen layout */
}
nav a {
font-size: 0.9em;
font-weight: bold;
text-decoration: none;
padding:2px 4px;
color: #000;
border: 1px solid #000;
line-height: 1.1em;
background-color: #DDDDDD;
margin:0 3px 3px 3px;
display:inline-block;
}
nav a:hover, nav a:focus {
background-color: #FFFFFF;
color:#000000;
text-decoration: none;
}
HTML:
<div class="mainbox">
<header>
<nav>
<a href="#cal" title="Cottage Availbility">Availability</a>
<a href="#tariff" title="Tariff">Tariff</a>
<a href="#" title="Make A Booking ">Make A Booking</a>
<a href="http://www.website.com/AccessStatement.pdf" title="Access Statement" target="_blank">Access Statement</a>
<a href="http://www.website.com/TandCs.pdf" title="T&Cs" target="_blank">T&Cs</a>
<a href="#contact" title="Contact the owners">Contact</a>
<a href="http://www.elsewhere.co.uk" title="Visit the website">
Parent Site</a>
</nav>
</header>
</div>