希望使用水平列制作inline-block。我需要每个inline-block都有宽度,作为符合内容的最小列数。
问题是用浏览器处理奇怪的列。
div {
height: 10em;
border: 1px solid red;
display: inline-block;
vertical-align: top;
-moz-column-width: 10em;
column-width: 10em;
-moz-column-fill: auto;
column-fill: auto;
}<div>
<p>Lorem ipsum dolor sit amet, an nec posse homero accumsan. Pro sale deseruisse ad. Vix cu integre fuisset insolens. Quo perfecto pericula ex. Te nam tritani honestatis, eam integre virtute ut.</p>
<p>Cum an autem affert laoreet, ea ius falli impedit ocurreret. No duo aperiam perfecto lobortis, ut mea aliquid graecis, te has facete sententiae. Ut singulis laboramus his, meis laoreet docendi ius ad. Duo nisl alterum perfecto no, eum in etiam laboramus prodesset, rebum nobis nusquam in sit. Usu at expetendis consectetuer.</p>
</div>
<div>
<p>Lorem ipsum dolor sit amet, an nec posse homero accumsan. Pro sale deseruisse ad. Vix cu integre fuisset insolens. Quo perfecto pericula ex. Te nam tritani honestatis, eam integre virtute ut.</p>
</div>
<div>
<p>Lorem ipsum dolor sit amet, an nec posse homero accumsan.</p>
</div>
<div>
<p>Lorem ipsum</p>
</div>
Chrome很可能会确定没有列的宽度,而不是将列放入该区域。第一个块有一个列的额外空间。其他块可以有一个列的宽度,但它们都有不同的宽度:

Firefox将所有块的宽度设置为单个列,并将其溢出。我可以在元素或它的任何容器上强制滚动条,但是我无法使它们中的任何一个具有正确的宽度。

我想让Chrome像Firefox一样运行,但这并不能帮助我解决这个问题:
div {
height: 10em;
border: 1px solid red;
display: inline-block;
vertical-align: top;
-moz-column-width: 10em;
column-width: 10em;
-moz-column-fill: auto;
column-fill: auto;
/* chrome to firefox */
width: -webkit-min-content;
width: min-content;
min-width: 10em;
}<div>
<p>Lorem ipsum dolor sit amet, an nec posse homero accumsan. Pro sale deseruisse ad. Vix cu integre fuisset insolens. Quo perfecto pericula ex. Te nam tritani honestatis, eam integre virtute ut.</p>
<p>Cum an autem affert laoreet, ea ius falli impedit ocurreret. No duo aperiam perfecto lobortis, ut mea aliquid graecis, te has facete sententiae. Ut singulis laboramus his, meis laoreet docendi ius ad. Duo nisl alterum perfecto no, eum in etiam laboramus prodesset, rebum nobis nusquam in sit. Usu at expetendis consectetuer.</p>
</div>
<div>
<p>Lorem ipsum dolor sit amet, an nec posse homero accumsan. Pro sale deseruisse ad. Vix cu integre fuisset insolens. Quo perfecto pericula ex. Te nam tritani honestatis, eam integre virtute ut.</p>
</div>
<div>
<p>Lorem ipsum dolor sit amet, an nec posse homero accumsan.</p>
</div>
<div>
<p>Lorem ipsum</p>
</div>
实际上,我需要得到这样的东西:

PS:Same question in russian.
发布于 2016-07-27 16:23:01
如果需要javascript,我有一个简单的解决方案,适用于固定大小的容器。如果大小可以动态更改,则需要重新计算(它应该首先重置内联样式)。
在Chrome 51,FF 47,IE 11和Opera 12中正确工作。
var divs = document.querySelectorAll("div");
for (var q=0; q<divs.length; ++q) {
//divs[q].style.width = ""; // Reset old value if refreshing
divs[q].style.width = divs[q].scrollWidth + 'px';
}div {
height: 10em;
border: 1px solid red;
display: inline-block;
vertical-align: top;
-moz-column-width: 10em;
column-width: 10em;
-moz-column-fill: auto;
column-fill: auto;
/* chrome to firefox */
width: -webkit-min-content;
width: min-content;
min-width: 10em;
}<div>
<p>Lorem ipsum dolor sit amet, an nec posse homero accumsan. Pro sale deseruisse ad. Vix cu integre fuisset insolens. Quo perfecto pericula ex. Te nam tritani honestatis, eam integre virtute ut.</p>
<p>Cum an autem affert laoreet, ea ius falli impedit ocurreret. No duo aperiam perfecto lobortis, ut mea aliquid graecis, te has facete sententiae. Ut singulis laboramus his, meis laoreet docendi ius ad. Duo nisl alterum perfecto no, eum in etiam laboramus prodesset, rebum nobis nusquam in sit. Usu at expetendis consectetuer.</p>
</div>
<div>
<p>Lorem ipsum dolor sit amet, an nec posse homero accumsan. Pro sale deseruisse ad. Vix cu integre fuisset insolens. Quo perfecto pericula ex. Te nam tritani honestatis, eam integre virtute ut.</p>
</div>
<div>
<p>Lorem ipsum dolor sit amet, an nec posse homero accumsan.</p>
</div>
<div>
<p>Lorem ipsum</p>
</div>
https://stackoverflow.com/questions/38598799
复制相似问题