flexbox - 将 Flexbox 'ul' 容器内的所有 'li' 图像设置为相同的固定大小
问题描述
我在每个li
标签中有一张图片,每张图片下方都有一些文字。parentul
和 childli
具有如下的 flexbox 属性。
父级 Ul:
{ display: flex; flex-wrap: row wrap; height: auto;}
李子:
ul.uploaded-pics li { flex: 0 1 auto; margin: 4px; align-self: center; vertical-align: middle; border-radius: 2px; }
ul.uploaded-pics label img { align-self: center; width: 100%; transition-duration: 0.2s; transform-origin: 50% 50%;}
我曾经align-self: center;
让图像与 parent 的中心对齐ul
。但是,图像大小并不一致,并且会根据每个相应标签中的文本量而变化。在标签文本流入第 2 或第 3 行的地方,上面的图像会拉伸以填充上面的空白区域。align-self: flex-start;
并且align-self: flex-end;
也无济于事,并且每个图像大小都不同li
。
li
无论下面的文本如何,如何修复图像大小label
,以便图像相互对齐并且文本标签也对齐?
找到下面的工作代码:
@import url('https://fonts.googleapis.com/css?family=Open+Sans');
ul.uploaded-pics { margin: 0; padding: 1px; border: 1px solid #aaa; border-radius: 4px}
ul.uploaded-pics { list-style-type: none;}
ul.uploaded-pics img { border: 2px;}
ul.uploaded-pics input[type="checkbox"]{ display: none;}
ul.uploaded-pics label { padding: 4px; display: block; position: relative; cursor: pointer; text-align: center; color: blue;}
ul.uploaded-pics label img { align-self: center; width: 100%; transition-duration: 0.2s; transform-origin: 50% 50%;}
ul.uploaded-pics { display: flex; flex-wrap: row wrap; height: auto;}
ul.uploaded-pics li { flex: 0 1 auto; margin: 4px; align-self: center; vertical-align: middle; border-radius: 2px; }
.pull-right .btn { margin-left: 5px;}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.2.1/jquery.min.js"></script>
<div id=Destination>Select the brands:
<ul class="uploaded-pics">
<li id=SubBrands>
<input class="SubBrandCheckBox" name="Brand1" type="checkbox"/>
<label><img src="https://pbs.twimg.com/media/DPt4SyVUEAIX4GZ.jpg" />Brand1</label>
</li>
<li id=SubBrands>
<input class="SubBrandCheckBox" name="Brand2" type="checkbox"/>
<label><img src="https://pbs.twimg.com/media/DPt4SybU8AAv8dm.jpg" />Brand2</label>
</li>
<li id=SubBrands>
<input class="SubBrandCheckBox" name="Brand3" type="checkbox"/>
<label><img src="https://pbs.twimg.com/media/DPt4SyVUEAIX4GZ.jpg" />XXXX XXXX XXXX XXXX XXXX Brand3</label>
</li>
<li id=SubBrands>
<input class="SubBrandCheckBox" name="Brand4" type="checkbox"/>
<label><img src="https://pbs.twimg.com/media/DPt4SybU8AAv8dm.jpg" />XXXX XXXX XXXX XXXX XXXX XXXX XXXX XXXX Brand4</label>
</li>
<li id=SubBrands>
<input class="SubBrandCheckBox" name="Brand5" type="checkbox"/>
<label><img src="https://pbs.twimg.com/media/DPt4SyVUEAIX4GZ.jpg" />Brand5</label>
</li>
</ul>
</div>
解决方案
您需要添加和align-self
如下:flex-basis
ul.uploaded-pics li
ul.uploaded-pics li {
align-self: flex-start;
flex-basis: 100%;
}
然后每一列的大小相同,并且图像适合它。您可以删除flex
属性 fromli
和flex-grow
属性 from,ul
因为它们是不必要的。
推荐阅读
- java - avd 打开主页但没有在 android studio 中显示我的应用
- r - 使用 ggplot2 从列表中绘制数据
- python-3.x - ValueError:在 LightGBM 中检测到圆形参考
- javascript - 无法使用全局或局部变量访问输入值
- ionic4 - 如何使用 CLI 生成 Stencil+Ionic4 PWA 组件
- java - RecyclerView - 获取选定的位置并将该位置传递给另一个活动,其中将显示相同的列表并选择该特定项目
- javascript - 在下拉列表中提交初始选择
- python - 为什么在尝试将文件分配给 Model.form 时出现属性错误??)
- python - 在这种情况下,可以将 itertools 用于未指定数量的维度吗?
- spring - 如何在 spring @Query 注释中放置带有变量的 n1ql 查询?