为了避免长列表,我将我的li设置为float:left以便它们交替行。然而,有时当li中的内容占用两行时,这会导致元素之间的无意间隙。我的HTML是:
<ul class="gmc-ingredient-list">
<li>500g Tagliatelle</li>
<li>50g wortel</li>
<li>50g ui</li>
<li>50g bleekselderij</li>
<li>100g pancetta</li>
<li>200g half-om-half-gehakt</li>
<li>200g rundergehakt</li>
<li>200 ml Primitivo (rode wijn)</li>
<li>200ml runderbouillon</li>
<li>5 eetlepels tomatenpuree</li>
<li>Olijfolie</li>
<li>Zeezout</li>
<li>Verse peper</li>
</ul>
我的CSS是:
ul.gmc-ingredient-list {
margin: 0;
padding: 0;
list-style: none;
width: 300px;
}
ul.gmc-ingredient-list li {
background: url(http://allesoveritaliaanseten.nl/wp-content/uploads/2012/11/aoie-list.png) no-repeat scroll left top transparent;
list-style: none outside none;
padding: 0px 0 0 20px;
width: 130px;
float: left;
}
输出看起来像http://allesoveritaliaanseten.nl/ragu-alla-bolognese/
但也有一些情况下,李占用两行,输出就像http://allesoveritaliaanseten.nl/italiaanse-tomatensoep/
一样好如何停止显示这些差距的列表?
答案 0 :(得分:4)
使用css3,您可以在列表中添加列
ul.gmc-ingredient-list {
margin: 0;
padding:0;
-moz-column-count: 2;
-moz-column-gap: 0;
-webkit-column-count: 2;
-webkit-column-gap: 0;
column-count: 2;
column-gap: 0;
width:300px;
}
ul.gmc-ingredient-list li {
background: url(http://allesoveritaliaanseten.nl/wp-content/uploads/2012/11/aoie-list.png) no-repeat scroll left top transparent;
list-style: none outside none;
padding: 0px 0 0 20px;
width:130px;
}
不要忘记从li
中删除浮动实施例: http://jsfiddle.net/LWBdp/3/
IE问题 CSS列似乎不适用于IE,如果你离开浮点数:留在那里它看起来就像你在IE中看起来一样,但在其他浏览器中看起来会更好!
有关css-columns的更多信息,请参阅w3schools
上的这篇文章答案 1 :(得分:1)
我建议您使用http://www.csscripting.com/css-multi-column/
我现在使用这个脚本很长一段时间,与其他可能的功能相比,它非常有效。如果您的站点使用AJAX完成,则必须修改此行: ut.XBrowserAddEventHandler(window,'load',function(){documentReady = true; processElements();});
编辑:此解决方案适用于任何浏览器,因为IE6 ...