本文介绍了CSS网格minmax(),最大宽度为100%的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
此代码使用CSS网格和 minmax(30rem,1fr)
。
This code uses CSS grid with minmax(30rem, 1fr)
.
grid-template-columns: repeat(auto-fill, minmax(30rem, 1fr));
一切正常,但是当 父容器小于30rem,将出现一个水平滚动条。我需要类似 minmax(min(30rem,100%),1fr))
之类的东西。知道如何实现吗?
Everything works fine, but when the parent container gets smaller than 30rem, a horizontal scrollbar appears. I would need something like minmax(min(30rem, 100%), 1fr))
. Any idea how to achieve that?
ul {
list-style-type: none;
padding: 0;
display: grid;
grid-template-columns: repeat(auto-fill, minmax(30rem, 1fr));
grid-auto-rows: 1fr;
grid-gap: 10px;
}
li {
background-color: #aaa;
padding: 0.5rem;
}
<ul class="list">
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<ul>
推荐答案
当屏幕宽度为 30rem
时,听起来像是断点。
Sounds like you have a breakpoint when the screen width is 30rem
. That calls for a media query.
将其添加到您的代码中:
Add this to your code:
@media (max-width: 30rem) {
ul { grid-template-columns: 1fr; }
}
ul {
list-style-type: none;
padding: 0;
display: grid;
grid-template-columns: repeat(auto-fill, minmax(30rem, 1fr));
grid-auto-rows: 1fr;
grid-gap: 10px;
}
li {
background-color: #aaa;
padding: 0.5rem;
}
@media (max-width: 30rem) {
ul {
grid-template-columns: 1fr;
}
}
<ul class="list">
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<li>grid item</li>
<ul>
这篇关于CSS网格minmax(),最大宽度为100%的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!