Ken*_*nny 4 html css grid css-grid angular
我正在尝试使用组件驱动的前端框架(例如Angular),最后学习CSS Grid。
我的问题是:筑巢 是坏习惯CSS Grids
吗?
我在这里所做的是在我的main / root组件中,我使用了CSS网格来完成两件事:navbar和主要内容区域,因为navbar将出现在整个应用程序以及主要内容中。
如下所示,根层次上的网格,然后是<nav-bar>
组件中的另一个网格。在主要内容区域中,我使用的每个/任何Angular组件中都会有更多的网格,可能是网格。
********************** ******************************
* Navbar * => * img | nav | logout *
********************** ******************************
**********************
* *
* Content *
* *
**********************
Run Code Online (Sandbox Code Playgroud)
下面的示例代码:
app.component.html
<div class="container">
<div class="item-navbar"></div>
<div class="item-nav">
<nav-bar></nav-bar>
</div>
<div class="item-content">
<router-outlet></router-outlet>
</div>
</div>
With this CSS:
.container {
display: grid;
grid: ". nav ."
". content ."
/ 3vh auto 3vh;
row-gap: 1vh;
}
.item-navbar {
grid-area: 1 / 1 / 2 / 4;
position: relative;
z-index: -1;
background: #579C87;
box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
}
.item-nav {
grid-area: nav;
}
.item-content {
grid-area: content;
background: #D1C7B8;
box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
}
Run Code Online (Sandbox Code Playgroud)
然后 nav-bar.component.html
<nav class="navbar" role="navigation" aria-label="main navigation">
<div class="navbar-brand">
<a class="navbar-item" routerLink="/">
<div class="img">
<img src="logo.jpg">
</div>
</a>
</div>
<div class="navbar-menu">
<a routerLink="/dashboard" class="navbar-item">Dashboard</a>
</div>
<div class="navbar-logout">
<a routerLink="/logout" class="navbar-item">Logout</a>
</div>
</nav>
with this CSS:
.navbar {
display: grid;
grid-template-columns: 64px auto auto;
grid-template-rows: auto;
grid-template-areas: "image navs logout";
gap: 1vh;
}
.navbar-brand {
grid-area: image;
place-self: center / start;
}
.navbar-menu {
grid-area: navs;
place-self: center start;
}
.navbar-logout {
grid-area: logout;
place-self: center end;
}
Run Code Online (Sandbox Code Playgroud)
这不是坏习惯,建议正确显示。
我有一个警告要提到,为了调试目的,将每个嵌套级别分成自己的文件。当嵌套多层深度时,单个丢失或错位</div>
会显着改变输出并且很难调试。我的建议是任何进一步的嵌套也应该分成单独的组件,这样每个级别都可以独立测试。
归档时间: |
|
查看次数: |
844 次 |
最近记录: |