我正在修补CSS网格,并想知道在调整屏幕大小时是否可能使嵌套网格移出其父网格。在CSS网格中从父网格中提取嵌套网格
我试过改变grid-template-areas
以包含“subcontent”,但这似乎是错误的并且扰乱了网格。
作为一个例子,我设置了以下模板,并希望在触发媒体断点时用“subcontent”div(粉红色)替换“配置文件”区域。
有没有什么办法可以在纯CSS的网格中做到这一点,而无需在JS中进行绑定?
.wrapper {
margin: auto;
width: 80%;
background-color: #e0e0e0;
display: grid;
grid-template-columns: 3fr 1fr;
grid-template-rows: 2fr 1fr 4fr;
grid-template-areas:
" title profile"
" infobar infobar "
" maincontent sidebar ";
grid-gap: 1em;
}
.space {
background-color: #eeeeee;
grid-area: space;
}
.title {
grid-area: title;
background-color: red;
}
.profile {
grid-area: profile;
background-color: orange;
}
.infobar {
grid-area: infobar;
background-color: yellow;
}
.maincontent {
grid-area: maincontent;
display: grid;
grid-template-columns: 2fr 1fr;
grid-template-rows: 1fr 1fr;
grid-template-areas:
"subcontent1 subcontent2"
"subcontent1 subcontent2";
background-color: green;
}
.subcontent1 {
grid-area: subcontent1;
background-color: pink;
margin: 10px;
}
.subcontent2 {
grid-area: subcontent2;
background-color: pink;
margin: 10px;
}
.sidebar {
grid-area: sidebar;
background-color: blue;
}
@media screen and (max-width: 900px) {
.wrapper {
grid-template-columns: 2fr 1fr 1fr;
grid-template-areas:
"title title sidebar"
"infobar infobar infobar"
"profile maincontent maincontent"
"footer footer sidebar"
;
}
.maincontent{
display: block;
}
.subcontent {
grid-area: subcontent;
}
}
<div class="wrapper">
<div class="title">Title</div>
<div class="profile">Profile</div>
<div class="infobar">Info Bar</div>
<div class="maincontent">Main Content
\t <div class="subcontent1">Main1</div>
\t <div class="subcontent2">Main2</div>
</div>
<div class="sidebar">Sidebar</div>
</div>
哎呀!感谢您指出模板领域的明显错误。我一定是在转移某些东西的时候离开了他们。 的“扰乱电网”我指的是更多的是试图像一个布局: “标题标题标题” “INFOBAR INFOBAR INFOBAR” “个人资料搜索Maincontent搜索Maincontent” “子内容子内容子内容” 谢谢指引我在正确的方向和信息链接! – GroomedGorilla