垂直对齐Flexbox项目并保持相同的宽度

时间:2016-07-07 11:16:44

标签: html css css3 flexbox

我有以下flexbox,我正在尝试垂直对齐项目并为每列保持相同的宽度。

假设我连续有10个项目,但内部容器应该只有4个项目可见,其余的则被溢出隐藏。所有这些项目都根据父容器的宽度

分割为相同的宽度

它似乎不起作用:

.container {
  width: 100%;
}
.container .slider {
  position: relative;
  overflow: hidden;
  margin: auto;
  padding: auto;
}
.container .slider[data-columns="1"] ul {
  width: 100%;
}
.container .slider[data-columns="1"] ul li {
  width: 100%;
}
.container .slider[data-columns="2"] ul {
  width: 200%;
}
.container .slider[data-columns="2"] ul li {
  width: 50%;
}
.container .slider[data-columns="3"] ul {
  width: 300%;
}
.container .slider[data-columns="3"] ul li {
  width: 33.33333%;
}
.container .slider[data-columns="4"] ul {
  width: 400%;
}
.container .slider[data-columns="4"] ul li {
  width: 25%;
}
.container .slider[data-columns="5"] ul {
  width: 500%;
}
.container .slider[data-columns="5"] ul li {
  width: 20%;
}
.container .slider[data-columns="6"] ul {
  width: 600%;
}
.container .slider[data-columns="6"] ul li {
  width: 16.66667%;
}
.container .slider[data-columns="7"] ul {
  width: 700%;
}
.container .slider[data-columns="7"] ul li {
  width: 14.28571%;
}
.container .slider[data-columns="8"] ul {
  width: 800%;
}
.container .slider[data-columns="8"] ul li {
  width: 12.5%;
}
.container .slider[data-columns="9"] ul {
  width: 900%;
}
.container .slider[data-columns="9"] ul li {
  width: 11.11111%;
}
.container .slider[data-columns="10"] ul {
  width: 1000%;
}
.container .slider[data-columns="10"] ul li {
  width: 10%;
}
.container .slider ul {
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
}
.container .slider ul li {
  height: 200px;
  list-style: none;
}
.container .slider ul li:nth-child(odd) {
  background-color: #34495e;
}
<div class="container">
 <div class="slider" data-columns ="4">
  <ul>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
    <li></li>
  </ul>
</div>  
</div>   

我的代码中缺少什么?

此处的Codepen演示:http://s.codepen.io/deroccha/debug/GqvvEm

2 个答案:

答案 0 :(得分:1)

要垂直对齐弹性项目,请将容器上的flex-directionrow切换为column

.container .slider ul {
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: column; /* ADJUSTMENT */
    flex-wrap: nowrap;
}

或者,当线上没有足够的空间时,您可以允许弹性项目换行:

.container .slider ul {
    margin: 0;
    padding: 0;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;    /* ADJUSTMENT */
}

基于修订问题的第二个答案:

禁用灵活项目收缩:

Flex容器的初始设置为flex-shrink: 1。这意味着允许弹性项目缩小(防止它们在flex-wrapnowrap时溢出容器。)

添加flex-shrink: 0以禁用缩小功能。

有关详细信息,请参阅此答案中的flex-shrink因素”部分:https://stackoverflow.com/a/34355447/3597276

.container .slider {
    overflow: hidden;
    margin: auto;
}

.container .slider[data-columns="4"] ul {
    width: 400%;
}

.container .slider[data-columns="4"] ul li {
    flex: 0 0 6.25%; /* don't grow, don't shrink, remain 6.25% width (25% / 4) */
}

.container .slider ul {
    margin: 0;
    padding: 0;
    display: flex;
}

.container .slider ul li {
    height: 200px;
    list-style: none;
    background-color: red;
}

.container .slider ul li:nth-child(odd) {
    background-color: blue;
}
<div class="container">
    <div class="slider" data-columns="4">
        <ul>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
            <li></li>
        </ul>
    </div>
</div>

答案 1 :(得分:0)

.container .slider ul css display: flex;更改为display: block;