- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
我的任务的完美解决方案是属性 column-gap
,但它还没有广泛支持 flexboxes。
所以我需要一个 hack 来即兴发挥这个功能。
最好的做法是什么?
我的愿望是使用justify-content: space-between;
。
这意味着例如对于一行中的 4 个对象:第一个对象没有左边距,行中的最后一个对象没有右边距。当然,对象之间应该有一个最小的水平间隙。
这意味着对于一行中的 1 个对象(小显示器):也没有左边距和右边距。
我尝试结合使用 margin、padding 和像 last-child 这样的伪类。但结果是,当显示太小以至于只能显示一列时,您必须重新设置所有这些规则。
最少的代码
#container {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
div {
flex: 1;
}
<div id="container">
<div>1</div>
<div>2</div>
<div>3</div>
<div>4</div>
</div>
我正在寻找解决问题的优雅方法。您必须使用宽度的媒体查询重置许多规则,其中只有一个对象适合一行。
感谢您的帮助。
最佳答案
我想我明白你想要什么,但你为什么特别想使用 justify-content: space-between
?
实现你想要的最简单的方法是在父 flex 容器和 margin-left: 1em
和margin-bottom: 1em
在 flex 子元素上。 flex 子元素的 margin-left
值必须与 flex 容器的负 margin-left
值相同。
* {
font-family: sans-serif;
box-sizing: border-box;
}
body {
margin: 0;
}
.flex-container {
display: flex;
flex-wrap: wrap;
margin-left: -1em;
}
.flex-item {
flex: 1;
background: #ccc;
border-radius: 3px;
text-align: center;
padding: 1em;
margin-left: 1em;
margin-bottom: 1em;
}
<div class="flex-container">
<div class="flex-item">Lorem ipsum dolor sit amet lorem ipsum dolor</div>
<div class="flex-item">Lorem ipsum dolor sit amet lorem ipsum dolor</div>
<div class="flex-item">Lorem ipsum dolor sit amet lorem ipsum dolor</div>
<div class="flex-item">Lorem ipsum dolor sit amet lorem ipsum dolor</div>
</div>
如果您愿意,您也可以为子级设置 min-width
。
根据您的评论并查看您的设计,我发现了一些错误。您会在下面找到一个代码片段,它向您展示了实现设计的正确方法。
一些建议:
id
(#),因为它们过于具体且难以覆盖。支持类和属性选择器。 box-sizing: border-box
,它使处理边距、填充和计算布局变得更加容易(请参阅 Marie Mosley 关于盒子大小的 article 以了解更多信息解释)margin
,请不要给它背景颜色或边框,因为这会破坏您的布局(这就是您给 #vorschau 时发生的情况
负边距和背景)。在父容器上设置背景、边框等。* {
box-sizing: border-box;
}
body {
background: rgb(220, 220, 220);
font-family: Roboto, Helvetica, Arial, sans-serif;
line-height: 1.5;
margin: 0;
}
h1, p {
margin: 0;
}
.flex-container {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.seite {
margin: 0 auto;
max-width: 70em;
background: #FAF2D5;
}
.huelle {
padding: 1.5em 2em;
}
.vorschau-container {
background: white;
border: 1px solid gray;
margin: 1em 0;
}
.vorschau {
margin-left: -2em;
margin-bottom: -2em;
}
.vorschau figure {
margin: 0 0 2em 2em;
text-align: center;
}
.vorschau img {
max-width: 14.5em;
border: 0.6em solid rgb(231, 231, 231);
}
<body class="galerie" cz-shortcut-listen="true">
<div class="seite">
<div class="huelle">
<h1>Lorem Ipsum</h1>
<div class="vorschau-container">
<div class="vorschau flex-container">
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Aufenthalt "Süd"</figcaption>
</figure>
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Bad "2. Quer"</figcaption>
</figure>
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Doppelzimmer</figcaption>
</figure>
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Eingangsbereich</figcaption>
</figure>
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Aufenthalt "1. Quer"</figcaption>
</figure>
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Küche "2. Quer"</figcaption>
</figure>
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Küche "1. Quer"</figcaption>
</figure>
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Aufenthalt "2. Quer"</figcaption>
</figure>
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Bad "1. Quer"</figcaption>
</figure>
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Bad "1. Quer"</figcaption>
</figure>
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Bad "1. Quer"</figcaption>
</figure>
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Bad "1. Quer"</figcaption>
</figure>
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Seminarwhg./Teeküche</figcaption>
</figure>
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Seminarwhg./Lounge</figcaption>
</figure>
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Seminarraum</figcaption>
</figure>
<figure>
<a href="#"><img src="https://via.placeholder.com/400x400" alt=""></a>
<figcaption>Seminarwhg./Zimmer</figcaption>
</figure>
</div>
</div>
<p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Fusce vehicula orci vitae felis congue porta. Maecenas finibus fermentum erat. Aenean pulvinar consequat arcu, ut pulvinar diam scelerisque non. Duis dapibus, mi nec pulvinar egestas, risus justo vehicula neque, in vestibulum turpis urna nec lacus.</p>
</div>
</div>
</body>
如果您需要进一步的解释,请在评论中提问;)
关于css - 具有多列和多行的 Flexbox 响应式布局 : Best practice to realize a "column-gap"?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55606496/
我刚刚更新了 Ruby,现在我在尝试启动 compass 时遇到以下错误: Encoding::CompatibilityError on line ["28"] of /usr/local/Cell
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 我们不允许提问寻求书籍、工具、软件库等的推荐。您可以编辑问题,以便用事实和引用来回答。 关闭 6 年前。
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我正在尝试在我的 iOS 应用程序中开发可折叠/ Accordion 式的功能。这将是您可以在网站上找到的典型 FAQ 类型功能。我想点击标题,然后显示详细信息。 因为这是帮助部分,只有几个项目,我认
我正在尝试设计一个基于 REST 的 Web 服务来与我正在开发的农场动物管理系统进行交互。 为了详细说明问题,我收藏了动物 属于一个农场。每只动物都有自己的信息——例如姓名、身份证号、品种年龄等。因
我有 3 种不同的表单,其中复选框数量不同,每个部分基本上代表一个表单,因此当用户选择该部分中的复选框时,它会显示他们在该部分的总金额中 checkout 了多少 HTML
我有一份 32 页的 PDF 版家谱。与其将家谱全部放在一个非常大的 PDF 页面上(这是我想要的),不如将其格式化为一组 8 个单独的美国信纸大小的页面应该在整个宽度上缝合; 4 行这样就完成了树。
指SASS implementation for Java? : 在 Maven 目标编译包中自动编译 compass-style.org 样式表的最佳方法是什么? 我不想发送太多的自编译库,也不想通
鉴于以下 XAML... 我正在寻找一种绑定(bind) ComboBox、Button 和 Command 的方法,以便当 ComboBox 的值更改时,在 Command 上调用 CanExe
在玩具应用程序中,我有一个显示所有帖子标题的“帖子”模板。当您单击每个标题时,我不想直接进入“显示” View ,而是直接内联展开该帖子的其余内容。 我考虑过让 postRoute 重用 postsR
我需要一些使用 Twitter Bootstrap 或其他响应式框架的自定义 Swagger-UI 实现。需要在我的移动设备上使用这样的 UI 测试我的 API,但 swagger-ui 不能很好地扩
我正在做一个项目,我真的在尝试编写面向对象的 JavaScript 代码。我刚刚开始阅读Douglas Crockford's JavaScript: The Good Parts我很快开始意识到用
在 C# 中,我通过执行以下操作来加密文本数据(请注意我正在以 block ( block )的形式加密数据): public string EncryptData(string pu
我正在构建一个社交网站,该网站将向全世界公开 REST API (WCF WebAPI),以便任何开发人员都能够为该网站创建客户端应用程序、将其与其他服务集成等。 我想为 API 实现 Faceboo
我是一名优秀的程序员,十分优秀!