使用grid来进行常见布局

grid 布局是W3C提出的一个二维布局系统,经过 display: grid 来设置使用,对于之前一些复杂的布局可以获得更简单的解决。本篇文章经过几个布局来对对 grid 布局进行一个简单的了解。目前,grid 仅仅只有 Edge使用前缀可以支持,为了更好地体验,能够使用 Chrome 浏览器,在 chrome://flags 开启 #enable-experimental-web-platform-features 选项。
另外,更多的例子能够前往 Grid by examples, 更多的用法能够前往 W3 Specification,也能够前往 A Complete Guide to Gridcss

Live Demohtml

左右固定中间自适应

之前,这须要使用 negative marginfloat, position 解决,圣杯布局是一个比较好的解决方案。后来,flex横空出世,使用 flex-growflex-basis 完成自适应布局。grid 布局相比 flex 布局更加简单,只须要在 container 上设置 grid-template-columns: 100px auto 100px
css3

.container {
  display: grid;
  grid-template-columns: 100px auto 200px;
}

三等分

之前的方法能够设置 float: left; width: 33.33333333,使用 flex 能够设置 flex-basis: 33.33333333。在 grid 中只须要设置 grid-template-columns: 1fr 1fr 1fr
git

.container {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  height: 100px;
  background-color: #feb;
}

三七分

在 grid 中设置 container 为十等分,能够使用 grid-template-columns: repeat(10, 1fr)
repeat 为重复10次 1frgrid-columngrid-column-startgrid-column-end 的缩写,表示起止的 line。使用 grid 进行栅格系统的布局也是很简单。
github

.container {
  display: grid;
  grid-template-columns: repeat(10, 1fr);
}

.column-3 {
  grid-column: 1 / 4;
}

.column-7 {
  grid-column: 4 / 11;
}

复杂布局

以上几个例子,均是单向布局,flex 就能很好的解决,而以下几个布局,均是二维布局,传统布局有些困难。如下示例图,能够在 container 上使用 grid-template-areas,在 item 上设置 grid-area 属性来设置复杂布局。
web

<div class="grid-layout">
  <div class="header">header</div>
  <div class="left">left</div>
  <div class="main">main</div>
  <div class="right">right</div>
  <div class="footer">footer</div>
</div>
.container {
  display: grid;
  grid-template-columns: 100px auto 100px;
  grid-template-rows: 40px 300px 50px;
  grid-template-areas: "header header header"
                       "left main right"
                       "footer footer footer";
}

.container .header {
  grid-area: header;
}

.container .footer {
  grid-area: footer;
}

.container .left {
  grid-area: left;
}

.container .right {
  grid-area: right;
}

.container .main {
  grid-area: main;
}

九宫格

在传统布局中就比较有困难。在 grid 中设置三行三列等宽,并使用 grid-gap 设置间隙。
<img src="https://shfshanyue.github.io/...; width="300" height="300">chrome

.container {
  width: 300px;
  height: 300px;
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  grid-template-rows: 1fr 1fr 1fr;
  grid-gap: 8px;
  border: 1px solid #fac;
  padding: 8px;
}

参考

相关文章
相关标签/搜索