国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > CSS > 正文

詳解css柵格系統在項目中的靈活運用

2024-07-11 08:59:19
字體:
來源:轉載
供稿:網友

前言

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 综艺| 临夏县| 新巴尔虎右旗| 安塞县| 托克托县| 化德县| 昌宁县| 繁昌县| 昆明市| 黄骅市| 井冈山市| 湟源县| 靖州| 浮梁县| 阳江市| 廉江市| 普安县| 濮阳市| 界首市| 乐至县| 库尔勒市| 伊春市| 宁河县| 肇庆市| 黎平县| 平凉市| 准格尔旗| 通辽市| 陆川县| 米脂县| 阿拉善盟| 泉州市| 芜湖市| 深水埗区| 兴和县| 连城县| 红安县| 绿春县| 华池县| 兴文县| 南雄市|