詳解css柵格系統(tǒng)在項(xiàng)目中的靈活運(yùn)用
前言
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)行展示。

分析
從圖中可以看到,柵格分兩種,一種是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>
小結(jié)
本文并沒有對(duì)css柵格的原理進(jìn)行說明,而是針對(duì)具體業(yè)務(wù)問題,說明如何用css柵格系統(tǒng)來提供解決問題的一種方案,對(duì)于柵格系統(tǒng)原理,請(qǐng)見參考部分,這個(gè)老外寫得非常詳細(xì)。
參考
Creating Your Own CSS Grid System
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
這篇文章主要介紹了淺談CSS 柵格系統(tǒng)原理分析,詳細(xì)介紹了Foundation、Pure、Bootstrap的使用方法,非常具有實(shí)用價(jià)值,需要的朋友可以參考下2017-11-07- 這篇文章主要介紹了詳解CSS中的柵格系統(tǒng),經(jīng)常被用于響應(yīng)式前端設(shè)計(jì)之中,需要的朋友可以參考下2015-07-28


