详解css栅格系统在项目中的灵活运用

前言

css栅格通常捆绑在各种框架中,但有时你需要自己去定制一个css栅格来满足实际的业务需要,本文聊聊css栅格系统在项目中的灵活运用。

需求

UI设计了如下布局,其中左上角橙色部分是固定的,蓝色部分是动态渲染的,从前往后依次展示,有一个就显示一块,有二个就显示二块,依次类推。如果数据多于6个,那么多余的数据,依次再在下方四列的地方进行展示。

分析

从图中可以看到,栅格分两种,一种是3列的栅格,一种是4列的栅格。当后端接口返回数据后,js需要进行判断:当数据大于6个时,前6个放在数组A中,数组A中的数据展示在3列的栅格中,多余部分放在数组B中,数组B中的数据展示在4列的栅格中。

html部分

<div id="app">  <div class="grid-container">    <div style="width: 25%; height: 220px; float: left; background-color: #FF6600; "></div>    <div class="row" style="width: 75%; float: right;">      <div class="col-3" v-for="(item, index) in groupListCol3" :key="index">        <div class="groups-cell">{{item.name}}</div>      </div>    </div>    <div class="row" style="width: 100%;">      <div class="col-4" v-for="(item, index) in groupListCol4" :key="index">        <div class="groups-cell">{{item.name}}</div>      </div>    </div>  </div></div>

css部分

.grid-container {      width: 100%;    }    .grid-container *{      box-sizing: border-box;    }    .grid-container .row:before,    .grid-container .row:after {      content: "";      display: table;      clear: both;    }    .grid-container [class*=col-] {      float: left;      min-height: 1px;      /*-- gutter --*/      padding: 0 0 20px 20px;    }    .grid-container .col-3{      width: 33.33%;      height: 120px;    }    .grid-container .groups-cell {      background-color: #66d3ff;      height: 100px;    }    .grid-container .col-4 {      width: 25%;      height: 120px;    }    .grid-container .col-4:nth-child(4n+1) {      padding: 0 0px 20px 0px;    }

注意:在4列的栅格中,每行的第一个单元格不需要padding-left,所以,最后,还得设置.col-4:nth-child(4n+1)的值。

js部分

<script src="https://cdn.bootcss.com/vue/2.5.16/vue.js"></script><script>  new Vue({    el: #app,    data: {      groupListCol3: [],      groupListCol4: []    },    created () {      let list = [        {name: A},        {name: B},        {name: C},        {name: D},        {name: E},        {name: F},        {name: G},        {name: H},        {name: I},        {name: J},        {name: K},        {name: L}      ]      if (list.length > 6) {        this.groupListCol3 = list.slice(0, 6)        this.groupListCol4 = list.slice(6)      } else {        this.groupListCol3 = list      }    }  })</script>

小结

本文并没有对css栅格的原理进行说明,而是针对具体业务问题,说明如何用css栅格系统来提供解决问题的一种方案,对于栅格系统原理,请见参考部分,这个老外写得非常详细。

参考

Creating Your Own CSS Grid System

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

详解css栅格系统在项目中的灵活运用