Grid systeem
Brûk ús krêftige mobyl-earste flexbox-raster om yndielingen fan alle foarmen en maten te bouwen mei tank oan in tolve kolomsysteem, fiif standert responsive tiers, Sass-fariabelen en mixins, en tsientallen foarôf definieare klassen.
Hoe't it wurket
It rastersysteem fan Bootstrap brûkt in searje konteners, rigen en kolommen om ynhâld yn te setten en út te rjochtsjen. It is boud mei flexbox en is folslein responsyf. Hjirûnder is in foarbyld en in yngeande blik op hoe't it raster byinoar komt.
Nij of net bekend mei flexbox? Lês dizze CSS Tricks flexbox-gids foar eftergrûn, terminology, rjochtlinen, en koadefragmenten.
It boppesteande foarbyld makket trije kolommen mei deselde breedte op lytse, medium, grutte en ekstra grutte apparaten mei ús foarôf definieare rasterklassen. Dy kolommen binne sintraal yn 'e side mei de âlder .container
.
It ôfbrekke, hjir is hoe't it wurket:
- Containers biede in middel om de ynhâld fan jo side te centreren en horizontaal op te foljen. Brûk
.container
foar in responsive pikselbreedte of.container-fluid
foarwidth: 100%
alle viewport- en apparaatgrutte. - Rigen binne wrappers foar kolommen. Elke kolom hat horizontaal
padding
(neamd in gutter) foar it kontrolearjen fan de romte tusken har. Ditpadding
wurdt dan tsjinwurke op de rigen mei negative marzjes. Op dizze manier wurdt alle ynhâld yn jo kolommen visueel oan 'e linkerkant ôfstimd. - Yn in rasteryndieling moat ynhâld binnen kolommen pleatst wurde en allinich kolommen kinne direkte bern fan rigen wêze.
- Mei tank oan flexbox sille gridkolommen sûnder in spesifisearre
width
automatysk yndieling as kolommen mei deselde breedte. Bygelyks, fjouwer eksimplaren fan.col-sm
sil elk automatysk wêze 25% breed fan de lytse breakpoint en omheech. Sjoch de auto-opmaak kolommen seksje foar mear foarbylden. - Kolomklassen jouwe it oantal kolommen oan dat jo brûke wolle út de mooglike 12 per rigel. Dus, as jo trije kolommen mei deselde breedte wolle, kinne jo gebrûk meitsje fan
.col-4
. - Kolom
width
s wurde ynsteld yn persintaazjes, sadat se altyd floeiber en grutte relatyf oan harren âlder elemint. - Kolommen hawwe horizontaal
padding
te meitsjen de goten tusken yndividuele kolommen, lykwols, kinne jo fuortsmite demargin
út rigen enpadding
út kolommen mei.no-gutters
op 'e.row
. - Om it raster responsyf te meitsjen, binne d'r fiif rasterbrekpunten, ien foar elk responsyf brekpunt : alle brekpunten (ekstra lyts), lyts, medium, grut en ekstra grut.
- Grid breakpoints binne basearre op minimale breedte media queries, wat betsjut dat se jilde foar dat iene breakpoint en al dy boppe it (bgl,
.col-sm-4
jildt foar lytse, medium, grutte en ekstra grutte apparaten, mar net it earstexs
brekpunt). - Jo kinne foarôf definieare rasterklassen (lykas
.col-4
) as Sass-mixins brûke foar mear semantyske markup.
Wês bewust fan de beheiningen en bugs om flexbox hinne , lykas it ûnfermogen om guon HTML-eleminten as flexcontainers te brûken .
Grid opsjes
Wylst Bootstrap brûkt em
s of rem
s foar it definiearjen fan de measte maten, px
s wurde brûkt foar grid breakpoints en container widths. Dit komt om't de sichtportbreedte yn piksels is en net feroaret mei de lettertypegrutte .
Sjoch hoe't aspekten fan it Bootstrap-rastersysteem wurkje oer meardere apparaten mei in handige tabel.
Ekstra lyts <576px |
Lyts ≥576px |
Medium ≥768px |
Grutte ≥992px |
Ekstra grut ≥1200px |
|
---|---|---|---|---|---|
Max container breedte | Gjin (auto) | 540px | 720px | 960px | 1140 px |
Klasse foarheaksel | .col- |
.col-sm- |
.col-md- |
.col-lg- |
.col-xl- |
# fan kolommen | 12 | ||||
Gootbreedte | 30px (15px oan elke kant fan in kolom) | ||||
Nestable | Ja | ||||
Kolombestelling | Ja |
Auto-opmaak kolommen
Brûk breakpoint-spesifike kolomklassen foar maklike kolomgrutte sûnder in eksplisite nûmere klasse lykas .col-sm-6
.
Gelikense breedte
Hjir binne bygelyks twa rasteryndielingen dy't jilde foar elk apparaat en viewport, fan xs
oant xl
. Foegje elk oantal klassen sûnder ienheid ta foar elk brekpunt dat jo nedich binne en elke kolom sil deselde breedte wêze.
Kolommen mei gelikense breedte kinne wurde ferdield yn meardere rigels, mar d'r wie in Safari flexbox-bug dy't foarkommen dat dit sûnder in eksplisite flex-basis
of border
. D'r binne oplossingen foar âldere browserferzjes, mar se soene net nedich wêze moatte as jo aktueel binne.
It ynstellen fan ien kolom breedte
Auto-yndieling foar flexbox-rasterkolommen betsjut ek dat jo de breedte fan ien kolom kinne ynstelle en de siblingskolommen automatysk feroarje om de grutte. Jo kinne foarôf definieare rasterklassen brûke (lykas hjirûnder werjûn), rastermixins, of ynline breedtes. Tink derom dat de oare kolommen de grutte sille feroarje, nettsjinsteande de breedte fan 'e middenkolom.
Ynhâld fan fariabele breedte
Brûk col-{breakpoint}-auto
klassen foar grutte kolommen basearre op de natuerlike breedte fan har ynhâld.
Equal-width multi-rige
Meitsje kolommen mei lykweardige breedte dy't meardere rigen oerspanje troch in yn te foegjen .w-100
wêr't jo wolle dat de kolommen nei in nije rigel brekke. Meitsje de pauzes responsyf troch de te mingjen .w-100
mei guon responsive display-hulpprogramma's .
Responsive klassen
It raster fan Bootstrap omfettet fiif lagen fan foarôf definieare klassen foar it bouwen fan komplekse responsive yndielingen. Pas de grutte fan jo kolommen oan op ekstra lyts, lyts, medium, grut of ekstra grutte apparaten lykas jo goed fine.
Alle brekpunten
Foar rasters dy't itselde binne fan 'e lytste apparaten oant de grutste, brûk de .col
en .col-*
klassen. Spesifisearje in nûmere klasse as jo nedich hawwe in bysûnder grutte kolom; oars, fiel frij om fêsthâlde oan .col
.
Steapele nei horizontaal
Mei help fan in inkele set fan .col-sm-*
klassen, kinne jo meitsje in basis raster systeem dat begjint út steapele en wurdt horizontaal op de lytse breakpoint ( sm
).
Mix en match
Wolle jo net dat jo kolommen gewoan steapele wurde yn guon rastertiers? Brûk in kombinaasje fan ferskate klassen foar elke tier as nedich. Sjoch it foarbyld hjirûnder foar in better idee fan hoe't it allegear wurket.
Gutters
Gutters kinne responsyf oanpast wurde troch breakpoint-spesifike padding en nutklassen foar negative marzjes. Om feroarjen de goten yn in opjûne rige, pair in negative marzje nut op 'e .row
en oerienkommende padding nutsbedriuwen op' e .col
s. De .container
of .container-fluid
âlder moat miskien ek oanpast wurde om net-winske oerstreaming te foarkommen, mei opnij oerienkommende padding-hulpprogramma.
Hjir is in foarbyld fan it oanpassen fan it Bootstrap-raster op it grutte ( lg
) brekpunt en boppe. Wy hawwe de .col
padding mei ferhege .px-lg-5
, dat tsjinwurke mei .mx-lg-n5
op 'e âlder .row
en dêrnei de omslach oanpast .container
mei .px-lg-5
.
Alignment
Brûk flexbox-ôfstimmingsprogramma's om kolommen fertikaal en horizontaal út te rjochtsjen. Internet Explorer 10-11 stipet gjin fertikale ôfstimming fan flexitems as de flexcontainer in hat min-height
lykas hjirûnder werjûn. Sjoch Flexbugs #3 foar mear details.
Fertikale ôfstimming
Horizontale ôfstimming
Gjin geiten
De goten tusken kolommen yn ús foarôf definieare rasterklassen kinne wurde fuortsmiten mei .no-gutters
. Dit smyt de negative margin
s út .row
en de horizontale padding
út alle direkte bern kolommen.
Hjir is de boarnekoade foar it meitsjen fan dizze stilen. Tink derom dat kolomoverriders allinich binne foar de earste bernkolommen en wurde rjochte fia attribútselektor . Wylst dit in mear spesifike selector genereart, kin kolompadding noch fierder oanpast wurde mei spacing utilities .
In edge-to-edge ûntwerp nedich? Drop de âlder .container
of .container-fluid
.
Yn 'e praktyk, hjir is hoe't it derút sjocht. Tink derom dat jo dit kinne trochgean mei alle oare foarôf definieare rasterklassen (ynklusyf kolombreedten, responsive tiers, opnij oarders, en mear).
Column wrapping
As mear as 12 kolommen wurde pleatst binnen ien rige, sil elke groep fan ekstra kolommen, as ien ienheid, wrap op in nije rigel.
Sûnt 9 + 4 = 13 > 12, dizze 4-kolom-wide div wurdt ferpakt op in nije line as ien oanienwei ienheid.
Folgjende kolommen trochgean lâns de nije line.
Kolom brekt
It brekken fan kolommen nei in nije rigel yn flexbox fereasket in lytse hack: foegje in elemint ta mei width: 100%
wêr't jo jo kolommen yn in nije rigel wolle wrapje. Normaal wurdt dit dien mei meardere .row
s, mar net elke útfiering metoade kin rekken mei dit.
Jo kinne dizze brek ek tapasse op spesifike brekpunten mei ús responsive display-hulpprogramma's .
Weromoardieling
Klassen bestelle
Brûk .order-
klassen foar it kontrolearjen fan de fisuele folchoarder fan jo ynhâld. Dizze klassen binne responsyf, dus jo kinne it order
troch brekpunt ynstelle (bygelyks .order-1.order-md-2
). Omfettet stipe foar 1
troch 12
alle fiif rasterlagen.
D'r binne ek responsive .order-first
en .order-last
klassen dy't de order
fan in elemint feroarje troch respektivelik oan te passen order: -1
en order: 13
( order: $columns + 1
). Dizze klassen kinne ek wurde kombinearre mei de nûmere .order-*
klassen as nedich.
Offset kolommen
Jo kinne rasterkolommen op twa manieren kompensearje: ús responsive .offset-
rasterklassen en ús marzje-nutsbedriuwen . Gridklassen binne grutte om te passen by kolommen, wylst marzjes handiger binne foar rappe opmaak wêr't de breedte fan 'e offset fariabel is.
Offset klassen
Ferpleats kolommen nei rjochts mei help fan .offset-md-*
klassen. Dizze klassen fergrutsje de loftermarge fan in kolom troch *
kolommen. Bygelyks, .offset-md-4
beweecht .col-md-4
oer fjouwer kolommen.
Neist kolom wiskjen by responsive breakpoints, moatte jo miskien offsets weromsette. Sjoch dit yn aksje yn it rasterfoarbyld .
Margin utilities
Mei de ferhuzing nei flexbox yn v4, kinne jo marzje-hulpprogramma's brûke lykas sibbenkolommen fan inoar .mr-auto
ôf te twingen.
Nesting
Om jo ynhâld mei it standertraster te nesteljen, foegje in nije .row
en set .col-sm-*
kolommen ta binnen in besteande .col-sm-*
kolom. Neste rigen moatte in set fan kolommen befetsje dy't 12 of minder optelle (it is net fereaske dat jo alle 12 beskikbere kolommen brûke).
Sass mixins
By it brûken fan Bootstrap's boarne Sass-bestannen, hawwe jo de opsje om Sass-fariabelen en mixins te brûken om oanpaste, semantyske en responsive side-layouts te meitsjen. Us foarôf definieare rasterklassen brûke deselde fariabelen en mixins om in heule suite fan klear te brûken klassen te leverjen foar rappe responsive yndielingen.
Fariabelen
Fariabelen en kaarten bepale it oantal kolommen, de gootbreedte en it mediafraachpunt wêrop driuwende kolommen begjinne moatte. Wy brûke dizze om de foarôf definieare rasterklassen te generearjen dy't hjirboppe dokuminteare binne, lykas foar de oanpaste mixins hjirûnder.
Mixins
Mixins wurde brûkt yn kombinaasje mei de rasterfariabelen om semantyske CSS te generearjen foar yndividuele rasterkolommen.
Foarbyld fan gebrûk
Jo kinne de fariabelen oanpasse oan jo eigen oanpaste wearden, of gewoan de mixins brûke mei har standertwearden. Hjir is in foarbyld fan it brûken fan de standertynstellingen om in opmaak mei twa kolommen te meitsjen mei in gat tusken.
It raster oanpasse
Mei ús ynboude raster Sass fariabelen en kaarten, is it mooglik om de foarôf definieare rasterklassen folslein oan te passen. Feroarje it oantal lagen, de dimensjes fan 'e mediafraach, en de kontenerbreedte - kompilearje dan opnij.
Kolommen en goaten
It oantal rasterkolommen kin wizige wurde fia Sass fariabelen. $grid-columns
wurdt brûkt om te generearjen de widths (yn prosint) fan elke yndividuele kolom wylst $grid-gutter-width
stelt de breedte foar de kolom gutters.
Grid tiers
Troch fierder te gean as de kolommen sels, kinne jo ek it oantal rasterlagen oanpasse. As jo mar fjouwer rasterlagen woene, soene jo de $grid-breakpoints
en bywurkje $container-max-widths
nei soksawat:
By it meitsjen fan wizigingen oan 'e Sass-fariabelen of kaarten, moatte jo jo wizigingen bewarje en opnij kompilearje. Troch dit te dwaan sil in gloednije set fan foarôf definieare rasterklassen útfiere foar kolombreedten, offsets en oardering. Responsive sichtberens sil ek bywurke wurde om de oanpaste brekpunten te brûken. Soargje derfoar dat jo rasterwearden ynstelle yn px
(net rem
, em
, of %
).