CSS网格-第一行限制高度

时间:2018-09-28 21:17:22

标签: html css css-grid

在我的Web应用程序中,我使用CSS网格构建基本主页。我希望顶部网格项:item-1尽可能高,以便整个网格填充视口。查看图片。

css-grid not fully covering viewport

因此,底部没有任何空隙。我尝试过调整包装器的高度,grid-template-rows中的行高以及更改每个单独项目的grid-column值中的数字。如何使第1项覆盖更多视口,并将其下方的4项向下移动以触摸底部?

.wrapper {
  margin-top: -25px;
  width:100vw;
  height: 70vh;
  // border: 2px solid #ccc;
  display: grid;
  grid-gap: 3px;
  grid-template-columns: repeat(4, 90px);
  grid-template-rows: repeat(4, 100px);
  justify-content: center;
  align-content: end;
  padding-bottom: 10px;
}

.box {
    background-color: #444;
    color: #fff;
    border-radius: 5px;
    padding: 10px;
    font-size: 150%;
    text-align: center;
  }

.item-1 {
  margin-top: 50px;
  background-image: url(../assets/imgs/placeholder.png);
  grid-column: 1 / 5;
  grid-row: 1 / 5;
}

.item-2 {
  grid-column: 1 / 3;
  background-color: rgba(250, 250, 250, 0.1);
}

.item-3 {
  grid-column: 3 / 5;
  background-color: rgba(250, 250, 250, 0.4);
}

.item-4 {
  grid-column: 1 / 3;
  background-color: rgba(250, 250, 250, 0.4);
}

.item-5 {
  grid-column: 3/ 5;
  background-color: rgba(250, 250, 250, 0.4);
}
<div class="wrapper">

    <div class="box item-1"></div>
    <div tappable (click)="loadAbout()" class="box item-2"><i class="icon fa fa-info"></i>About</div>
    <div tappable (click)="loadHowTo()" class="box item-3"><i class="icon fa fa-question"></i>How To</div>
  <div tappable (click)="loadList()" class="box item-4"><i class="icon fa fa-signal"></i>List</div>
<div tappable (click)="loadContact()" class="box item-5"><i class="icon fa fa-comments"></i>Contact Us</div>
</div>

2 个答案:

答案 0 :(得分:2)

将包装器grid-template-rows设置为自动100px 100px。

html,
body {
  font-family: Arial;
  margin: 0;
  padding: 0;
}

.grid {
  width: 100vw;
  height: 100vh;
  background: #333;
  display: grid;
  grid-template-rows: auto 100px 100px;
  grid-template-columns: repeat(4, 90px);
  grid-gap: 5px;
  justify-content: center;
}
.grid * {
  color: white;
  font-size: 120%;
  background: rgba(255, 255, 255, 0.3);
  display: flex;
  align-items: center;
  justify-content: center;
}
.grid .grid-item-1 {
  grid-column: 1 / 5;
  grid-row: 1;
}
.grid .grid-item-2,
.grid .grid-item-3 {
  grid-row: 2;
}
.grid .grid-item-4,
.grid .grid-item-5 {
  grid-row: 3;
}
.grid .grid-item-2,
.grid .grid-item-4 {
  grid-column: 1 / 3;
}
.grid .grid-item-3,
.grid .grid-item-5 {
  grid-column: 3 / 5;
}
<div class="grid">
  <div class="grid-item-1"></div>
  <div class="grid-item-2">about</div>
  <div class="grid-item-3">how to</div>
  <div class="grid-item-4">list</div>
  <div class="grid-item-5">contact us</div>
</div>

答案 1 :(得分:0)

使width: 100vh;.wrapper的div成为.item-1可能是您想要的。这应该省略对负边距,填充底部和对齐内容属性的需要。

希望有帮助!

.wrapper {
  /*   margin-top: -25px; */
  width: 100vw;
  height: 100vh; /*   made 100vh */
  /*   // border: 2px solid #ccc; */
  display: grid;
  grid-gap: 3px;
  grid-template-columns: repeat(4, 90px);
  grid-template-rows: repeat(4, 100px);
  justify-content: center;
  /*   align-content: end; */
  /*   padding-bottom: 10px; */
}

.box {
  background-color: orange;
  color: #fff;
  border-radius: 5px;
  padding: 10px;
  font-size: 150%;
  text-align: center;
}

.item-1 {
  /*   margin-top: 50px; */
  background-image: url(../assets/imgs/placeholder.png);
  grid-column: 1 / 5;
  grid-row: 1 / 5;
  height: 100vh;
}

.item-2 {
  grid-column: 1 / 3;
  background-color: rgba(250, 250, 250, 0.1);
}

.item-3 {
  grid-column: 3 / 5;
  background-color: rgba(250, 250, 250, 0.4);
}

.item-4 {
  grid-column: 1 / 3;
  background-color: rgba(250, 250, 250, 0.4);
}

.item-5 {
  grid-column: 3/ 5;
  background-color: rgba(250, 250, 250, 0.4);
}
<div class="wrapper">
  <div class="box item-1"></div>
  <div tappable (click)="loadAbout()" class="box item-2"><i class="icon fa fa-info"></i>About</div>
  <div tappable (click)="loadHowTo()" class="box item-3"><i class="icon fa fa-question"></i>How To</div>
  <div tappable (click)="loadFreq()" class="box item-4"><i class="icon fa fa-signal"></i>List</div>
  <div tappable (click)="loadContact()" class="box item-5"><i class="icon fa fa-comments"></i>Contact Us</div>
</div>