Rooster stelsel
Gebruik ons kragtige mobiele-eerste flexbox-rooster om uitlegte van alle vorms en groottes te bou danksy 'n twaalf kolomstelsel, vyf verstek-responsiewe vlakke, Sass-veranderlikes en -mengsels, en dosyne voorafbepaalde klasse.
Hoe dit werk
Bootstrap se roosterstelsel gebruik 'n reeks houers, rye en kolomme om inhoud uit te lê en in lyn te bring. Dit is gebou met flexbox en reageer ten volle. Hieronder is 'n voorbeeld en 'n in-diepte blik op hoe die rooster bymekaar kom.
Nuut by of onbekend met Flexbox? Lees hierdie CSS Tricks flexbox-gids vir agtergrond, terminologie, riglyne en kodebrokkies.
Die voorbeeld hierbo skep drie kolomme met gelyke breedte op klein, medium, groot en ekstra groot toestelle deur ons vooraf gedefinieerde roosterklasse te gebruik. Daardie kolomme is gesentreer in die bladsy met die ouer .container
.
Om dit af te breek, hier is hoe dit werk:
- Houers bied 'n manier om jou werf se inhoud te sentreer en horisontaal te vul. Gebruik
.container
vir 'n responsiewe piekselwydte of.container-fluid
virwidth: 100%
alle kykpoort en toestelgroottes. - Rye is omhulsels vir kolomme. Elke kolom het horisontale
padding
(genoem 'n geut) om die spasie tussen hulle te beheer. Ditpadding
word dan teengewerk op die rye met negatiewe marges. Op hierdie manier is al die inhoud in u kolomme visueel aan die linkerkant in lyn. - In 'n roosteruitleg moet inhoud binne kolomme geplaas word en slegs kolomme mag onmiddellike kinders van rye wees.
- Danksy flexbox sal roosterkolomme sonder 'n gespesifiseerde
width
outomaties as gelyke breedte kolomme uitleg. Byvoorbeeld, vier gevalle van.col-sm
sal elkeen outomaties 25% breed wees vanaf die klein breekpunt en hoër. Sien die outo-uitlegkolomme- afdeling vir meer voorbeelde. - Kolomklasse dui die aantal kolomme aan wat jy uit die moontlike 12 per ry wil gebruik. Dus, as jy drie kolomme met dieselfde breedte wil hê, kan jy
.col-4
. - Kolom
width
s word in persentasies gestel, so hulle is altyd vloeibaar en groot relatief tot hul moederelement. - Kolomme het horisontale
padding
om die geute tussen individuele kolomme te skep, maar jy kan diemargin
van rye enpadding
van kolomme met.no-gutters
op die verwyder.row
. - Om die rooster responsief te maak, is daar vyf roosterbreekpunte, een vir elke responsiewe breekpunt : alle breekpunte (ekstra klein), klein, medium, groot en ekstra groot.
- Roosterbreekpunte is gebaseer op medianavrae met 'n minimum breedte, wat beteken dat hulle van toepassing is op daardie een breekpunt en almal daarbo (bv. van
.col-sm-4
toepassing op klein, medium, groot en ekstra groot toestelle, maar nie die eerstexs
breekpunt nie). - Jy kan vooraf gedefinieerde roosterklasse (soos
.col-4
) of Sass-mengings gebruik vir meer semantiese opmaak.
Wees bewus van die beperkings en foute rondom flexbox , soos die onvermoë om sommige HTML-elemente as flex-houers te gebruik .
Grid opsies
Terwyl Bootstrap em
s of rem
s gebruik om die meeste groottes te definieer, px
word s gebruik vir roosterbreekpunte en houerwydtes. Dit is omdat die kykpoortwydte in pixels is en nie verander met die lettergrootte nie .
Kyk hoe aspekte van die Bootstrap-roosterstelsel oor verskeie toestelle werk met 'n handige tabel.
Ekstra klein <576px |
Klein ≥576 px |
Medium ≥768 px |
Groot ≥992px |
Ekstra groot ≥1200px |
|
---|---|---|---|---|---|
Maksimum houer breedte | Geen (outo) | 540 px | 720 px | 960px | 1140 px |
Klas voorvoegsel | .col- |
.col-sm- |
.col-md- |
.col-lg- |
.col-xl- |
# van kolomme | 12 | ||||
Geut breedte | 30px (15px aan elke kant van 'n kolom) | ||||
Nesbaar | Ja | ||||
Kolombestelling | Ja |
Outo-uitlegkolomme
Gebruik breekpunt-spesifieke kolomklasse vir maklike kolomgrootte sonder 'n eksplisiete genommerde klas soos .col-sm-6
.
Gelyke breedte
Hier is byvoorbeeld twee roosteruitlegte wat op elke toestel en kykpoort van toepassing is, van xs
tot xl
. Voeg enige aantal eenheidlose klasse by vir elke breekpunt wat jy nodig het en elke kolom sal dieselfde breedte hê.
Gelyke breedte kolomme kan in veelvuldige lyne opgebreek word, maar daar was 'n Safari flexbox fout wat verhoed het dat dit werk sonder 'n eksplisiete flex-basis
of border
. Daar is oplossings vir ouer blaaierweergawes, maar dit behoort nie nodig te wees as jy op datum is nie.
Stel een kolombreedte in
Outo-uitleg vir flexbox-roosterkolomme beteken ook dat jy die breedte van een kolom kan stel en die broers en susterkolomme outomaties die grootte rondom dit kan verander. Jy kan vooraf gedefinieerde roosterklasse (soos hieronder getoon), roostermengsels of inlynwydtes gebruik. Let daarop dat die ander kolomme se grootte sal verander, ongeag die breedte van die middelkolom.
Veranderlike breedte inhoud
Gebruik col-{breakpoint}-auto
klasse om kolomme te grootte gebaseer op die natuurlike breedte van hul inhoud.
Gelyke breedte multi-ry
Skep gelyke breedte kolomme wat oor verskeie rye strek deur 'n in te voeg .w-100
waar jy wil hê die kolomme moet breek na 'n nuwe lyn. Maak die pouses reageer deur die te meng .w-100
met 'n paar responsiewe vertoonhulpmiddels .
Responsiewe klasse
Bootstrap se rooster bevat vyf vlakke van voorafbepaalde klasse vir die bou van komplekse responsiewe uitlegte. Pasmaak die grootte van jou kolomme op ekstra klein, klein, medium, groot of ekstra groot toestelle soos jy goeddink.
Alle breekpunte
Vir roosters wat dieselfde is van die kleinste toestelle tot die grootste, gebruik die .col
en .col-*
klasse. Spesifiseer 'n genommerde klas wanneer jy 'n besondere grootte kolom benodig; anders, hou gerus by .col
.
Gestapel tot horisontaal
Deur 'n enkele stel .col-sm-*
klasse te gebruik, kan jy 'n basiese roosterstelsel skep wat gestapel begin en horisontaal word by die klein breekpunt ( sm
).
Meng en pas
Wil jy nie hê dat jou kolomme eenvoudig in sommige roostervlakke gestapel moet word nie? Gebruik 'n kombinasie van verskillende klasse vir elke vlak soos nodig. Sien die voorbeeld hieronder vir 'n beter idee van hoe dit alles werk.
Geute
Geute kan responsief aangepas word deur breekpunt-spesifieke vulling en negatiewe marge-nutsklasse. Om die geute in 'n gegewe ry te verander, koppel 'n negatiewe marge-hulpmiddel op die .row
en bypassende opvulhulpprogramme op die .col
s. Die .container
of .container-fluid
ouer sal dalk ook aangepas moet word om ongewenste oorloop te vermy, deur weer bypassende opvullingshulpmiddel te gebruik.
Hier is 'n voorbeeld van die pasmaak van die Bootstrap-rooster by die groot ( lg
) breekpunt en hoër. Ons het die .col
vulling vergroot met .px-lg-5
, dit teengewerk met .mx-lg-n5
op die ouer en dan die omhulsel .row
aangepas met ..container
.px-lg-5
Belyning
Gebruik flexbox-belyningshulpmiddels om kolomme vertikaal en horisontaal in lyn te bring. Internet Explorer 10-11 ondersteun nie vertikale belyning van buigsame items wanneer die buighouer 'n min-height
soos hieronder getoon het nie. Sien Flexbugs #3 vir meer besonderhede.
Vertikale belyning
Horisontale belyning
Geen geute nie
Die geute tussen kolomme in ons vooraf gedefinieerde roosterklasse kan verwyder word met .no-gutters
. Dit verwyder die negatiewe margin
s van .row
en die horisontalepadding
van alle onmiddellike kinders kolomme.
Hier is die bronkode vir die skep van hierdie style. Let daarop dat kolomverwerpings slegs na die eerste kinderkolomme gedek word en via kenmerkkieser geteiken word . Alhoewel dit 'n meer spesifieke kieser genereer, kan kolomvulling steeds verder aangepas word met spasiëringsnutsmiddels .
Het jy 'n rand-tot-rand-ontwerp nodig? Los die ouer .container
of .container-fluid
.
In die praktyk, hier is hoe dit lyk. Let daarop dat jy kan voortgaan om dit te gebruik met alle ander voorafbepaalde roosterklasse (insluitend kolomwydtes, responsiewe vlakke, herbestellings en meer).
Kolom wikkel
As meer as 12 kolomme binne 'n enkele ry geplaas word, sal elke groep ekstra kolomme, as een eenheid, op 'n nuwe lyn toegedraai word.
Aangesien 9 + 4 = 13 > 12, word hierdie 4-kolom-wye div op 'n nuwe lyn toegedraai as een aaneenlopende eenheid.
Volgende kolomme gaan voort langs die nuwe lyn.
Kolombreuke
Om kolomme na 'n nuwe lyn in flexbox te breek, vereis 'n klein hack: voeg 'n element by width: 100%
waar jy jou kolomme ook al wil omvou na 'n nuwe lyn. Normaalweg word dit met veelvuldige s bewerkstellig .row
, maar nie elke implementeringsmetode kan hiervoor rekening hou nie.
Jy kan ook hierdie breek by spesifieke breekpunte toepas met ons responsiewe vertoonhulpmiddels .
Herrangskik
Bestel klasse
Gebruik .order-
klasse om die visuele volgorde van jou inhoud te beheer. Hierdie klasse reageer, so jy kan die order
deurbreekpunt (bv. .order-1.order-md-2
). Sluit ondersteuning in vir 1
deur 12
al vyf roostervlakke.
Daar is ook responsiewe .order-first
en .order-last
klasse wat die order
van 'n element verander deur order: -1
en order: 13
( order: $columns + 1
), onderskeidelik toe te pas. Hierdie klasse kan ook vermeng word met die genommerde .order-*
klasse soos nodig.
Verrekening van kolomme
Jy kan roosterkolomme op twee maniere verreken: ons responsiewe .offset-
roosterklasse en ons marge-hulpprogramme . Roosterklasse is gegrootte om by kolomme te pas, terwyl marges nuttiger is vir vinnige uitlegte waar die wydte van die afwyking veranderlik is.
Verreken klasse
Skuif kolomme na regs deur .offset-md-*
klasse te gebruik. Hierdie klasse vergroot die linkerkantlyn van 'n kolom met *
kolomme. .offset-md-4
Beweeg byvoorbeeld .col-md-4
oor vier kolomme.
Benewens die skoonmaak van kolomme by responsiewe breekpunte, moet jy dalk afwykings terugstel. Sien dit in aksie in die roostervoorbeeld .
Marge nutsdienste
Met die skuif na flexbox in v4, kan u marge-hulpmiddels gebruik soos .mr-auto
om broers en susterskolomme van mekaar weg te dwing.
Nestel
Om jou inhoud met die verstekrooster te nes, voeg 'n nuwe .row
en stel .col-sm-*
kolomme binne 'n bestaande .col-sm-*
kolom by. Geneste rye moet 'n stel kolomme insluit wat tot 12 of minder optel (dit word nie vereis dat jy al 12 beskikbare kolomme gebruik nie).
Snaakse mengsels
Wanneer u Bootstrap se bron-Sass-lêers gebruik, het u die opsie om Sass-veranderlikes en -mengings te gebruik om pasgemaakte, semantiese en responsiewe bladsyuitlegte te skep. Ons voorafbepaalde roosterklasse gebruik dieselfde veranderlikes en mengsels om 'n hele reeks gereed-vir-gebruik-klasse te verskaf vir vinnige responsiewe uitlegte.
Veranderlikes
Veranderlikes en kaarte bepaal die aantal kolomme, die geutwydte en die medianavraagpunt waar swewende kolomme begin word. Ons gebruik dit om die voorafbepaalde roosterklasse wat hierbo gedokumenteer is te genereer, sowel as vir die pasgemaakte mengsels hieronder gelys.
Mengsels
Mixins word saam met die roosterveranderlikes gebruik om semantiese CSS vir individuele roosterkolomme te genereer.
Voorbeeld gebruik
Jy kan die veranderlikes verander na jou eie persoonlike waardes, of gebruik net die mixins met hul verstekwaardes. Hier is 'n voorbeeld van die gebruik van die verstek instellings om 'n twee-kolom uitleg te skep met 'n gaping tussen.
Pasmaak van die rooster
Deur ons ingeboude rooster Sass veranderlikes en kaarte te gebruik, is dit moontlik om die vooraf gedefinieerde roosterklasse heeltemal aan te pas. Verander die aantal vlakke, die medianavraag-dimensies en die houerwydtes—stel dan weer saam.
Kolomme en geute
Die aantal roosterkolomme kan via Sass-veranderlikes gewysig word. $grid-columns
word gebruik om die wydtes (in persent) van elke individuele kolom te genereer terwyl $grid-gutter-width
die breedte vir die kolomgeute bepaal word.
Roostervlakke
As u verder as die kolomme self beweeg, kan u ook die aantal roostervlakke aanpas. As jy net vier roostervlakke wil hê, sal jy die $grid-breakpoints
en opdateer $container-max-widths
na iets soos hierdie:
Wanneer jy enige veranderinge aan die Sass veranderlikes of kaarte maak, sal jy jou veranderinge moet stoor en hersaamstel. Deur dit te doen, sal 'n splinternuwe stel voorafbepaalde roosterklasse vir kolomwydtes, verskuiwings en ordening uitstuur. Hulpmiddels vir responsiewe sigbaarheid sal ook opgedateer word om die pasgemaakte breekpunte te gebruik. Maak seker dat jy roosterwaardes in px
(nie rem
, em
, of %
) stel nie.