溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

css柵格系統(tǒng)在項(xiàng)目中靈活運(yùn)用的示例分析

發(fā)布時(shí)間:2021-06-10 11:27:22 來源:億速云 閱讀:125 作者:小新 欄目:web開發(fā)

這篇文章主要介紹了css柵格系統(tǒng)在項(xiàng)目中靈活運(yùn)用的示例分析,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

前言

css柵格通常捆綁在各種框架中,但有時(shí)你需要自己去定制一個(gè)css柵格來滿足實(shí)際的業(yè)務(wù)需要,本文聊聊css柵格系統(tǒng)在項(xiàng)目中的靈活運(yùn)用。

需求

UI設(shè)計(jì)了如下布局,其中左上角橙色部分是固定的,藍(lán)色部分是動(dòng)態(tài)渲染的,從前往后依次展示,有一個(gè)就顯示一塊,有二個(gè)就顯示二塊,依次類推。如果數(shù)據(jù)多于6個(gè),那么多余的數(shù)據(jù),依次再在下方四列的地方進(jìn)行展示。

css柵格系統(tǒng)在項(xiàng)目中靈活運(yùn)用的示例分析

分析

從圖中可以看到,柵格分兩種,一種是3列的柵格,一種是4列的柵格。當(dāng)后端接口返回?cái)?shù)據(jù)后,js需要進(jìn)行判斷:當(dāng)數(shù)據(jù)大于6個(gè)時(shí),前6個(gè)放在數(shù)組A中,數(shù)組A中的數(shù)據(jù)展示在3列的柵格中,多余部分放在數(shù)組B中,數(shù)組B中的數(shù)據(jù)展示在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列的柵格中,每行的第一個(gè)單元格不需要padding-left,所以,最后,還得設(shè)置.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>

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“css柵格系統(tǒng)在項(xiàng)目中靈活運(yùn)用的示例分析”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來學(xué)習(xí)!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

css
AI