首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使网格项只占用行中的剩余空间?

如何使网格项只占用行中的剩余空间?
EN

Stack Overflow用户
提问于 2021-05-28 07:09:26
回答 2查看 79关注 0票数 0

我想让网格项目2,3,4挤压到顶部,它不应该从它的自然网格线开始。我想移除网格项目(2-3)和网格项目3-4之间的水平额外空间。我怎样才能做到这一点?

网格项1可以是任意高度。它是动态的。

代码语言:javascript
复制
.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.container>div {
  background-color: teal;
  border-radius: 1rem;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 2rem;
  color: whitesmoke;
}

.item1 {
  grid-row: 1/4;
  height: 500px;
}

.item2,
.item3,
.item4 {
  height: 100px;
}
代码语言:javascript
复制
<div class="container">
  <div class="item1">1</div>
  <div class="item2">2</div>
  <div class="item3">3</div>
  <div class="item4">4</div>
</div>

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2021-05-28 07:25:10

我喜欢考虑网格是抽象层而不是固定结构。这样,您可以自由地将div放置到网格块中,而不是网格块。

按照这种模式,定义一个8行的网格,并告诉您的div占据"x“行就可以做到这一点。可以随意使用行号和跨度,以更好地满足您的需要。:)

代码语言:javascript
复制
.container {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
}

.container>div {
  background-color: teal;
  border-radius: 1rem;
  display: flex;
  justify-content: center;
  align-items: center;
  font-size: 2rem;
  color: whitesmoke;
}

.item1 {
  grid-row: 1/8;
  height: 500px;
}

.item2,
.item3,
.item4 {
  grid-row: span 2;
  height: 100px;
}
代码语言:javascript
复制
<div class="container">
  <div class="item1">1</div>
  <div class="item2">2</div>
  <div class="item3">3</div>
  <div class="item4">4</div>
</div>

这是这个想法的草图:

票数 1
EN

Stack Overflow用户

发布于 2021-05-28 07:30:13

最简单的方法是添加另一个可以展开的行。

代码语言:javascript
复制
.item1 {
  grid-row: 1/5;
  height: 500px;
}

grid-row: 1/5意味着网格将有4行。这允许3项流到右侧的顶部,第四行可以根据需要展开。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67734336

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档