- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我设置了一个包含两个元素的网格。此网格可以包含任意数量的元素,但对于此示例来说两个就足够了。
在示例中,有两个灰色框向左对齐。在宽屏(大于 1000 像素)上使用检查器,我们可以发现第三个(或更多)“阴影”元素,它填满了剩余的空间。
如何让方框在网格中居中?就像“影子”元素不存在一样。
在 .grid
元素上,我仍然想使用网格,因为我不需要编写自动媒体查询。在 wrapper 上,一切皆有可能。
此外,固定宽度也不是一个选项。
.wrap {
display: flex;
flex-direction: column;
/*justify-content: center;
align-items: center;*/
}
.grid {
display: grid;
grid-template-columns: repeat(auto-fill, minmax(100px, 1fr));
grid-gap: 1rem;
}
.item {
background: #eee;
}
<div class="wrap">
<div class="grid">
<div class="item">
Item 1
</div>
<div class="item">
Item 2
</div>
</div>
</div>
最佳答案
您的问题最有效的解决方案可能是 flexbox,因为 flex 元素并不像网格元素那样局限于单个轨道(列/行)。
.grid {
display: flex;
flex-wrap: wrap;
margin-bottom: 1em;
}
.item {
flex: 1 0 100px;
background: #eee;
text-align: center;
border: 1px dashed gray;
box-sizing: border-box;
}
<div class="grid">
<div class="item">Item 1</div>
</div>
<div class="grid">
<div class="item">Item 1</div>
<div class="item">Item 2</div>
</div>
<div class="grid">
<div class="item">Item 1</div>
<div class="item">Item 2</div>
<div class="item">Item 3</div>
</div>
<div class="grid">
<div class="item">Item 1</div>
<div class="item">Item 2</div>
<div class="item">Item 3</div>
<div class="item">Item 4</div>
</div>
但如果您想坚持使用网格布局,这里有一些需要考虑的问题和可能的解决方案。
1fr
当您说 1fr
时,就像您在代码中所做的那样,这意味着 “消耗所有可用空间”。但是当没有空闲空间时,就不可能对齐。
关键字对齐属性(即 justify-*
和 align-*
)通过分配可用空间来工作。它们不能左对齐、右对齐、space-between
、space-around
或居中,没有可用空间。
这不仅仅是网格行为。它是标准的 HTML/CSS:div
默认是 block 级元素。这意味着它占据其父元素的 100% 宽度。因此 div
不能居中(除非您覆盖默认设置)。
网格中的列和行延伸到整个容器。因此,假设 auto-fill
创建三列后,所有后续行都将具有三列。
如果第一行有三个网格项,第二行有两个网格项,则第二行仍有第三列穿过(并占用空间)。因此,第二行的两项不能在线居中。
自动填充
当repeat()
函数设置为auto-fill
或auto-fit
时,容器会创建尽可能多的网格轨道不会溢出容器。
使用自动填充
,当没有网格项来填充所有创建的轨道时,这些轨道将被保留。基本上,网格布局保持固定,有或没有元素。
您在问题中指出了这一点。您有两个网格元素,但也存在其他“影子”元素。请注意,这些“影子”项不是网格项。它们只是空的网格单元格。
由于网格单元格为空,因此没有剩余空间可用于将网格项居中。
自动适应
auto-fit
关键字与 auto-fill
的作用相同,不同之处在于:折叠空轨道。
在您的情况下,由于您在 minmax()
函数中将 1fr
设置为最大大小,因此额外的空间分布在两个网格项中。
同样,不可能居中,但这一次是因为 fr
单元占用了所有可用空间(如上面的 1fr
部分所述)。
对齐内容:居中
如上所述,无法将网格元素居中,因为该行上没有可用于对齐目的的可用空间。
解决此问题的一种方法(仍然允许灵活的列大小)是使用 max-content
而不是 1fr
,以及 auto-fit
.
.grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(100px, max-content));
justify-content: center;
grid-gap: 1rem;
}
.item {
background: #eee;
}
<div class="grid">
<div class="item">Item 1</div>
</div>
<hr>
<div class="grid">
<div class="item">Item 1</div>
<div class="item">Item 2</div>
</div>
<hr>
<div class="grid">
<div class="item">Item 1</div>
<div class="item">Item 2</div>
<div class="item">Item 3</div>
</div>
<hr>
<div class="grid">
<div class="item">Item 1</div>
<div class="item">Item 2</div>
<div class="item">Item 3</div>
<div class="item">Item 4</div>
</div>
关于html - 在自动填充容器中居中网格元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49514794/
我正在尝试将 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
我是一名优秀的程序员,十分优秀!