gpt4 book ai didi

html - 垂直对齐 flexbox 元素并保持相同的宽度

转载 作者:行者123 更新时间:2023-11-28 16:11:37 26 4
gpt4 key购买 nike

我有以下 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

最佳答案

要垂直对齐 flex 元素,请将容器上的 flex-directionrow 切换到 column

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

或者,当行中没有足够的空间时,您可以允许 flex 元素换行:

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

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

禁用 flex 元素的收缩:

flex 容器的初始设置是flex-shrink: 1。这意味着允许 flex 元素收缩(防止它们在 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>

关于html - 垂直对齐 flexbox 元素并保持相同的宽度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38244098/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com