- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有多个较小的固定大小的 div float 在容器 div 中。我希望它们等距分布,以便整个 block 给人以居中对齐的印象。
Right now they are aligned to the left (这就是 float 的工作原理,我知道)。我知道这不太可能,但我只是想要一些 hack,这样我就可以实现同样的目标。
One way to do that是计算必要的宽度(假设我每行需要 3 个 div,每个 100px 宽,10px 边距。因此容器的总宽度应为 100*3+60)并将该宽度应用于容器 div 并设置边距自动。
#container {
width: 360px;
margin: 0px auto;
}
.items { /* these are smaller divs */
width: 100px;
margin: 10px;
float: left;
}
但这在不同的屏幕尺寸下看起来不太好,除非我专门为不同的媒体设置宽度。
Another way is to use the flex display .
#container {
display: flex;
flex-wrap:wrap;
justify-content: space-between;
}
.items { /* these are smaller divs */
flex: 0 0 auto;
width: 100px;
margin: 10px;
}
它几乎达到了我的目的,但问题是当你在底行有多个 div 时,它只是将第二个 div 放在最右边,而不是在第二列下对齐(这也是我知道的预期行为,没有任何问题)。
那么,对于我想要实现的目标,有什么技巧/技巧吗?
更新(针对重复报告):另一个问题的解决方案(报告与此问题相同)使用固定容器宽度,而我在上面提到我不想固定容器宽度。所以那个解决方案不是我要找的。
下面 Josh 提到了完美的解决方案,只更改了 justify-content: space-around,这样即使窗口变窄,内容也能保持居中。
最佳答案
So, are there any tricks/hacks for what I want to achieve?
这绝对是一个 hack,但它似乎有效。您可以添加一些 height
为 0
的空 flexbox 元素作为占位符。这样做时,将按预期计算 flexbox 元素放置,因为将考虑空 flexbox 元素的宽度并填充空间。
空 flexbox 元素的最小数量应该等于一行中 flexbox 元素的最大数量减一。当然,您可以随时添加更多……以防万一。
在下面的示例中,我使用了 :empty
pseudo class选择空的占位符 flexbox 元素。
相关的CSS:
.items:empty {
visibility: hidden;
height: 0;
width: 100px;
margin: 0 10px 0;
}
完整的 HTML/CSS:
#container {
background-color: #000;
display: flex;
flex-wrap: wrap;
justify-content: space-around;
margin: 25px auto;
}
.items {
flex: 0 0 auto;
width: 100px;
margin: 10px;
}
#item1 {
background-color: #F00;
}
#item2 {
background-color: #0F0;
}
#item3 {
background-color: #00F;
}
#item4 {
background-color: #ABC;
}
#item5 {
background-color: #A00;
}
#item6 {
background-color: #6AF;
}
#item7 {
background-color: #07A;
}
#item8 {
background-color: #A79;
}
#item9 {
background-color: #AF4;
}
#item10 {
background-color: #FF4;
}
.items:empty {
visibility: hidden;
height: 0;
width: 100px;
margin: 10px;
margin-top: 0;
margin-bottom: 0;
}
<div id="container">
<div id="item1" class="items">a</div>
<div id="item2" class="items">b</div>
<div id="item3" class="items">c</div>
<div id="item4" class="items">c</div>
<div id="item5" class="items">c</div>
<div id="item6" class="items">c</div>
<div id="item7" class="items">c</div>
<div id="item8" class="items">c</div>
<div id="item9" class="items">c</div>
<div id="item10" class="items">c</div>
<div class="items"></div><div class="items"></div><div class="items"></div><div class="items"></div><div class="items"></div><div class="items"></div><div class="items"></div><div class="items"></div><div class="items"></div>
</div>
关于css - 在容器内居中 div,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33850687/
我正在尝试将 Bootstrap 输入字段置于列 div 的中心,但我尝试过的所有方法似乎都不起作用。 到目前为止我尝试了什么: Enter the inf
这是它的样子: http://i.imgur.com/H0Oqz4Q.png 这是 CSS: #header{ background:url('header.png'); border-radius:
似乎有一个 align 属性工作得非常好,但是可以对齐元素,因此面板上的所有元素都将对齐,以在彼此底部居中,如果它们都小于容器尺寸?类似顶部中心中心的东西。 类似这样的事情: 或者至少水平方向和垂直方
我用 GUI 创建了一个简单的猜谜游戏。问题是,每当我最大化窗口时,整个 GUI 都会卡在顶部中间。我想知道如何将其居中以及如何使其变大。代码如下: import javax.swing.*;
目前我在另一个 View 中有一个 View (它是一个广告),但是因为我使用的是 MATCH_PARENT,所以宽度是整个屏幕的长度,而我只希望它是广告尺寸。现在 WRAP_CONTENT 解决了这
我有一个 UIViewController 子类,它实例化了一个 UIView 子类(我们称之为 viewA)。然后,viewA 有时会实例化另一个 UIView,我们称之为 viewB。 我希望 v
我是 Cocca 和 IOS 开发的新手,发现自己处于以下情况。 我有一张 1024x1024 的背景图片,我想在所有 View 中显示它。我已将以下代码放在应用程序委托(delegate)中的应用程
我正在尝试使用 MathML 作为 HTML5 的一部分来制作居中的盒装数学方程式。问题是盒子。如果我在我的 div 元素上放置一个边框,边框足够高,但它一直延伸到屏幕的左侧和右侧。如果我在我的数学元
我知道这听起来很简单,但它不适合我。我做错了什么? .popuphdr { background-color:#00477f; height:30px; width
我正在为我的网店创建一个新网站 - 我遇到了这个 css 问题...... 系统是在prestashop平台上制作的,但是这是基本的CSS,所以没关系。 在 CMS 页面上,我在将页面居中时遇到问题,
我有一个横跨整个屏幕宽度的按钮: accusantium quia sunt 44% 我希望第一个段落标签中的文本居中,其背景图像紧挨着文本。问题是第一个 居中
http://makememodern.com/portfolio/ 您会看到我在页面上嵌入了一个网站,并且它与页面右侧对齐。我希望它居中。 最佳答案 您将 iframe 的宽度设置为 1100
我的 header 中有一个元素正在从 js 文件中获取数据。 我试图将该元素置于我的页面的中心,但我所做的一切似乎都有效。 我尝试了 margin-left: auto 和 margin-right
这个问题在这里已经有了答案: What does auto do in margin: 0 auto? (8 个答案) 关闭 7 年前。
我试图让这两个按钮并排对齐,在页面的中心垂直和水平。 几个小时以来,我一直在摆弄它,尝试了所有方法,但我无法让它既与页面居中对齐又并排对齐 我希望有人能给我指出正确的方向。谢谢..
我需要将一个 img 居中(带有 class=“key”的那个,但是 float 元素阻止了它。我应该使用什么技术将其居中? 谢谢! GitHub 存储库:https://github.com/Cal
每次我嵌入来自 Google map 的 iframe 时,它都会将标记保留在中间。 即使有工具提示并且只是剪切工具提示数据,它也会这样做: http://jsfiddle.net/V2SVa/
我无法将这些按钮置于页面中央。我只知道我错过了一些愚蠢的东西,但我不知道是什么。这是页面: All Time Last 2 Weeks La
我如何将 div 内的表格 div 对齐到 align=center 最佳答案 asd 关于html - div对齐=居中,我们在Stack Overflow上找到一个类似的问题: htt
有人知道如何在调整浏览器窗口大小时也实现垂直居中吗? 水平效果很好,图像大小调整也很好。我希望图片和链接始终在浏览器中间居中。 另外,为什么 ul 没有像图像那样居中而是向右移动了一点? Here i
我是一名优秀的程序员,十分优秀!