加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

CSS栅格系统在实际的项目中怎么运用

发布时间:2023-10-12 14:52:32 所属栏目:语言 来源:
导读:css栅格通常捆绑在各种框架中,但有时你需要自己去定制一个css栅格来满足实际的业务需要,本文聊聊css栅格系统在项目中的灵活运用。

需求

UI设计了如下布局,其中左上角橙色部分是固定的,蓝色部分是动态渲染
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>
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章