【发布时间】:2019-10-30 08:37:33
【问题描述】:
使用 CSS 网格布局,我创建了一个网站,其布局会随着屏幕大小而略有变化。
在这里,为了将内容(粉红色区域)保持在 CSS 网格布局的中心,我做了以下样式。
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
.text {
color: #fff;
}
.bg {
background-color: #6c757d;
}
footer {
width: 100%;
display: grid;
grid-template-columns: minmax(20%, 1fr) auto minmax(20%, 1fr);
grid-template-rows: repeat(3, auto);
}
h1,
dl {
grid-column: 2;
background-color: pink;
}
p.h6 {
grid-row: 3;
grid-column: 3;
overflow-wrap: break-word;
}
@media (max-width: 800px) {
p.h6 {
grid-column: 2;
}
}
body>p {
text-align: center;
}
<footer class="bg text">
<h1>
heading
</h1>
<dl class="h6">
<dt>word1</dt>
<dd>desc1</dd>
<dt>word2</dt>
<dd>desc2</dd>
</dl>
<p class="h6">COPYRIGHT(C)loooooooooooooooooooooooooongtext</p>
</footer>
<p>↑<br>true center</p>
当宽度较宽时这似乎效果很好,但当宽度较小时,粉红色区域会偏离“真正的中心”。
这也说明minmax (20%, 1fr)不能正常工作。
如何让这个粉色区域居中?另外,有没有比我上面想的更好的方法? (使用 CSS 网格布局)
【问题讨论】:
-
你只是溢出,40% + 最小内容宽度(标题宽度)超过 100%
-
@TemaniAfif 是的。我想的代码有问题。我认为的代码在粉红色区域居中,但由于屏幕宽度等原因,它没有居中。您通常如何使用 CSS Grid Layout 解决这些(主要是
overflow)问题? -
只需将 minmax() 更改为
1fr,我真的不认为这里需要20% -
@TemaniAfif 如果你只使用
1fr,当屏幕变小时,粉色区域会被版权文本向左推。这将使用minmax函数,因为粉红色区域将不再是“真正的中心”。 -
因为您使用的是 strange 长字符串。添加一些空格就可以了。我不认为你真的会有这样的版权
标签: html css css-grid centering