<li> s </li>之间的差距

时间:2013-01-21 12:55:06

标签: html css html-lists gaps-in-visuals

为了避免长列表,我将我的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/

一样好

如何停止显示这些差距的列表?

2 个答案:

答案 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 ...