CSS Grid does not grow when inside flexbox(在Flexbox中时,CSS网格不会增长)
本文介绍了在Flexbox中时,CSS网格不会增长的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我对css网格的理解是,它将增长以填充其父对象,但是当父对象的大小由FlexBox控制时,这似乎不能正常工作。
在this example中,我预计淡蓝色网格项会增长到覆盖红色区域。如果网格是独立的,这将正确工作,但一旦将其放置到Flex元素中(即使使用flex-grow: 1),它就完全不会增长;
这里发生了什么,有什么方法可以将样式调整为我预期的行为吗?
编码:
布局
<div class="normal-grid">
<div class="grid-item">Thing 1</div>
<div class="grid-item">Thing 2</div>
</div>
<div class="flex">
<div class="flex-grid">
<div class="grid-item">Thing 1</div>
<div class="grid-item">Thing 2</div>
</div>
</div>
样式
.normal-grid {
height: 100px;
display: grid;
grid-template-columns: 1fr 1fr;
grid-template-rows: 1fr;
background: red;
}
.flex {
margin-top: 20px;
height: 100px;
display: flex;
flex-direction: column;
}
.flex-grid {
flex-grow: 1;
display: grid;
grid-template-columns: 1fr 1fr;
grid-template-rows: 1fr;
background: red;
}
.grid-item {
background: lightblue;
}
推荐答案
只需保持row方向(默认方向)即可获得拉伸效果:
.normal-grid {
height: 100px;
display: grid;
grid-template-columns: 1fr 1fr;
grid-template-rows: 1fr;
background: red;
}
.flex {
margin-top: 20px;
height: 100px;
display: flex;
/*flex-direction: column;*/
}
.flex-grid {
flex-grow: 1;
display: grid;
grid-template-columns: 1fr 1fr;
grid-template-rows: 1fr;
background: red;
}
.grid-item {
background: lightblue;
}
<div class="normal-grid">
<div class="grid-item">Thing 1</div>
<div class="grid-item">Thing 2</div>
</div>
<div class="flex">
<div class="flex-grid">
<div class="grid-item">Thing 1</div>
<div class="grid-item">Thing 2</div>
</div>
</div>
这篇关于在Flexbox中时,CSS网格不会增长的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
织梦狗教程
本文标题为:在Flexbox中时,CSS网格不会增长
基础教程推荐
猜你喜欢
- 检查 HTML5 拖放文件类型 2022-01-01
- 原生拖动事件后如何获取 mouseup 事件? 2022-01-01
- fetch 是否支持原生多文件上传? 2022-01-01
- 即使用户允许,Gmail 也会隐藏外部电子邮件图片 2022-01-01
- npm start 错误与 create-react-app 2022-01-01
- Fabric JS绘制具有活动形状的多边形 2022-01-01
- 如何添加到目前为止的天数? 2022-01-01
- Bootstrap 模态出现在背景下 2022-01-01
- Bokeh Div文本对齐 2022-01-01
- 在 contenteditable 中精确拖放 2022-01-01
