CSS3列切断<li> s </li>

时间:2012-08-12 11:36:12

标签: html css3 multiple-columns

我正在尝试使用带有列表(<li>)的css3列。 我无法正常工作。

我定义了一个包裹<ul>

的div
div.ul-container {
  -moz-column-width: 310px;
  -moz-column-gap: 10px;
  -webkit-column-width: 310px;
  -webkit-column-gap: 10px;
  column-width: 310px;
  column-gap: 10px;
}

当我有三个<li>或更高时,这可以正常工作。但是当我的数量少于(2或1)时,它似乎会切断<li>。我尝试定义min-height但效果不佳(将其视为高度)。

截图:

cutting off li

任何想法?

2 个答案:

答案 0 :(得分:15)

这个帖子有点老了,但我最近遇到了同样的问题并用它来防止列表项被删除:

li {
-webkit-column-break-inside: avoid;
          page-break-inside: avoid;
               break-inside: avoid;
}

有关CSS-Tricks

的更多信息

希望它可以帮助同一条船上的任何人!

答案 1 :(得分:0)

似乎与li元素和ol上的边距相关联。 首先来自jsfiddle.net/nZUB9我reseted your CSS,然后将margin: 6px 0;转换为padding: 6px 0; 它为我做了工作;)

/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/

html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, em, img, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var,
b, u, i, center,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, embed, 
figure, figcaption, footer, header, hgroup, 
menu, nav, output, ruby, section, summary,
time, mark, audio, video {
    margin: 0;
    padding: 0;
    border: 0;
    font-size: 100%;
    font: inherit;
    vertical-align: baseline;
}
/* HTML5 display-role reset for older browsers */
article, aside, details, figcaption, figure, 
footer, header, hgroup, menu, nav, section {
    display: block;
}
body {
    line-height: 1;
}
ol, ul {
    list-style: none;
}
blockquote, q {
    quotes: none;
}
blockquote:before, blockquote:after,
q:before, q:after {
    content: '';
    content: none;
}
table {
    border-collapse: collapse;
    border-spacing: 0;
}


* {
margin: 0;
padding: 0;
font-family: arial, verdana;
}

.task-wrapper {
-moz-column-width: 310px;
-moz-column-gap: 10px;
-webkit-column-width: 310px;
-webkit-column-gap: 10px;
column-width: 310px;
column-gap: 10px;
    border:1px solid red;
}

ol.tasks {
list-style-type: none;
margin-left: 0;
    display: block;
}

ol.tasks li {
border-bottom: 1px dotted rgba(0, 30, 30, 0.3);
background-color: white;
background-color: rgba(255, 255, 255, 0.9);
}

ol.tasks li {
border: 1px solid rgba(0, 30, 30, 0.3);
padding: 6px 0;
list-style-type: decimal;
width: 310px;
}