sîstema Grid
Bi saya pergalek diwanzdeh stûnan, pênc rêzikên xwerû yên bersivdar, guhêrbar û mixînên Sass, û bi dehan çînên pêşwextkirî, tora flexbox-a meya yekem-mobîl-a hêzdar bikar bînin da ku sêwiranên ji her şekl û mezinahiyê ava bikin.
Çawa dixebite
Pergala torê ya Bootstrap rêzek konteyneran, rêzik û stûnan bikar tîne da ku naverok saz û rêz bike. Ew bi flexbox ve hatî çêkirin û bi tevahî bersivdar e. Li jêr mînakek û nihêrînek kûr heye ku meriv çawa tevna hev dike.
Nû bi flexbox re an nizanin? Vê rêberê flexbox-ê ya CSS Tricks ji bo paşnav, termînolojî, rêbername, û perçeyên kodê bixwînin.
Mînaka li jor sê stûnên bi firehiya wekhev li ser cîhazên piçûk, navîn, mezin û zêde mezin bi karanîna çînên tora meya pêşwextkirî diafirîne. Ew stûn di nav rûpelê de bi dêûbav re têne navend kirin .container
.
Bi şikandina wê, li vir çawa dixebite:
- Konteyner amûrek peyda dike ku naverok û horizontî naverokên malpera we dakêşin. Ji
.container
bo firehiyek pixelek bersivdar an.container-fluid
ji bowidth: 100%
hemî pîvanên dîmenderê û cîhazê bikar bînin. - Rêz ji bo stûnan pêçan in.
padding
Ji bo kontrolkirina cîhê di navbera wan de her stûnek horizontî heye (ku jê re goşt tê gotin). Dûv re evpadding
yek li ser rêzên bi margîneyên neyînî tê berevajîkirin. Bi vî rengî, hemî naveroka di stûnên we de bi dîtbarî li milê çepê têne rêz kirin. - Di sêwirana torê de, naverok divê di nav stûnan de were danîn û tenê stûn dikarin yekser zarokên rêzikan bin.
- Bi saya flexbox, stûnên torê yên bêyî diyarkirî
width
dê bixweber wekî stûnên firehiya yeksan werin sêwirandin. Mînakî, çar nimûneyên.col-sm
dê her yek bixweber ji xala veqetînê ya piçûk û jor 25% fireh bin. Ji bo nimûneyên bêtir li beşa stûnên xweser- sazkirinê binêrin. - Dersên stûnê hejmara stûnên ku hûn dixwazin ji 12-yên gengaz ên di rêzê de bikar bînin destnîşan dikin. Ji ber vê yekê, heke hûn sê stûnên bi firehiya wekhev dixwazin, hûn dikarin bikar bînin
.col-4
. - Stûnên
width
s bi sedî têne danîn, ji ber vê yekê ew her gav li gorî hêmana dêûbavê xwe şil û mezin in. - Stûnên horizontî hene
padding
da ku di navbera stûnên takekesî de gemaran biafirînin, lêbelê, hûn dikarinmargin
ji rêzan ûpadding
ji stûnên bi.no-gutters
ser.row
. - Ji bo ku torê bibe bersiv, pênc xalên şikestinê hene, yek ji bo her xala veqetandinê ya bersivdar : Hemî xalên veqetandinê (piçûk zêde), piçûk, navîn, mezin û zêde mezin.
- Xalên veqetandinê yên torê li ser bingeha pirsên medyaya herî kêm fireh in, tê vê wateyê ku ew li ser wê xala veqetînê û hemî yên li jor wê bicîh dibin (mînak,
.col-sm-4
ji bo cîhazên piçûk, navîn, mezin û zêde mezin derbas dibe, lê ne xalaxs
veqetînê ya yekem). - Hûn dikarin ji bo nîşankirina bêtir semantîk dersên torê yên pêşwextkirî (wek
.col-4
) an Sass mîksên bikar bînin.
Hay ji sînorkirin û xeletiyên li dora flexbox-ê hebin , mîna nebûna karanîna hin hêmanên HTML-ê wekî konteynerên nerm .
Vebijarkên Grid
Dema ku Bootstrap em
s an rem
s-yê ji bo danasîna pir pîvanan bikar tîne, px
s ji bo xalên veqetandinê û firehiyên konteynerê têne bikar anîn. Ji ber ku firehiya porta dîtinê bi pixel e û bi mezinahiya tîpan nayê guhertin .
Binêrin ka aliyên pergala tora Bootstrap-ê li ser gelek cîhazên bi tabloyek bikêr çawa dixebitin.
Zêde piçûk <576px |
Piçûk ≥576px |
Navîn ≥768px |
Mezin ≥992px |
Zêde mezin ≥1200px |
|
---|---|---|---|---|---|
Firehiya konteynerê herî zêde | Tune (otomatîk) | 540px | 720px | 960px | 1140px |
Pêşgira dersê | .col- |
.col-sm- |
.col-md- |
.col-lg- |
.col-xl- |
# stûnan | 12 | ||||
Firehiya gulikê | 30px (15px li her aliyê stûnekê) | ||||
Nestable | Erê | ||||
Siparîşa stûnê | Erê |
Stûnên Auto-layout
Ji bo mezinbûna stûnê ya hêsan bêyî çînek jimarekirî ya eşkere mîna .col-sm-6
.
Wekhev-fireh
Mînakî, li vir du sêwiranên torê hene ku li ser her amûr û dîmenderê, ji xs
heya xl
. Ji bo her xala veqetandinê ya ku hûn hewce ne, hejmarek dersên yekîneyek kêm zêde bikin û her stûn dê heman firehiyê be.
Stûnên bi firehiya wekhev dikarin di gelek rêzan de werin şikandin, lê xeletiyek Safari flexbox hebû ku rê li ber vê yekê girt ku bêyî eşkere flex-basis
an border
. Ji bo guhertoyên gerokên kevntir rêgir hene, lê heke hûn nûve bin divê ew ne hewce bin.
Sazkirina yek width stûnê
Vesazkirina otomatîkî ya ji bo stûnên tora flexbox di heman demê de tê vê wateyê ku hûn dikarin firehiya yek stûnê destnîşan bikin û stûnên xwişk û bira bixweber li dora wê mezin bibin. Hûn dikarin çînên torê yên pêşwextkirî (wek ku li jêr tê xuyang kirin), mîksên torê, an firehiyên hundurîn bikar bînin. Bala xwe bidinê ku stûnên din dê mezinahiya stûna navendê nebe.
Naveroka firehiya guherbar
Dersan bikar bînin col-{breakpoint}-auto
ku stûnan li gorî firehiya xwezayî ya naveroka wan mezin bikin.
Pir-rêzek wekhev-fireh
.w-100
Bi danîna cîhê ku hûn dixwazin stûn di xêzek nû de biherikin stûnên wekhev-fireh ên ku gelek rêzan vedigirin biafirînin. Bi tevlîhevkirina .w-100
hin amûrên dîmendera bersivdar veqetiyan bikin.
Dersên bersivdar
Tora Bootstrap ji bo avakirina sêwiranên bersivdar ên tevlihev pênc rêzikên dersên diyarkirî vedihewîne. Mezinahiya stûnên xwe li ser cîhazên piçûk, piçûk, navîn, mezin, an zêde mezin lê hûn guncaw dibînin, xweş bikin.
Hemû xalên veqetînê
Ji bo torên ku ji cîhazên herî piçûk heya herî mezin yek in, çînên .col
û bikar bînin. .col-*
Dema ku hûn hewceyê stûnek bi taybetî bi mezinahî hewce bikin, çînek hejmarkirî diyar bikin; wekî din, xwe azad hîs bikin ku pê ve girêdayî bin .col
.
Berbi horizontal ve hatî berhev kirin
Bi karanîna komek çînek yekane .col-sm-*
, hûn dikarin pergalek torê ya bingehîn biafirînin ku ji hev veqetandî dest pê dike û li xala veqetîna piçûk ( sm
) dibe horîzontal.
Mix û hev bikin
Ma hûn naxwazin stûnên we bi tenê di hin rêzikên torê de werin berhev kirin? Li gorî hewcedariyê ji bo her rêzek hevbendiyek çînên cûda bikar bînin. Ji bo ramanek çêtir ka ew hemî çawa dixebite, mînaka jêrîn bibînin.
Gutters
Gutters dikarin bi bersivdayinê ji hêla dersên padding-taybetî û marjînalên neyînî ve werin sererast kirin. Ji bo guheztina kelûpelên di rêzek diyarkirî de, amûrek marjînalek negatîf li ser hev bikin .row
û li ser s-yê karûbarên padding bihevre bikin .col
. Dibe ku pêdivî .container
be .container-fluid
ku dêûbav jî were guheztin da ku ji zêdebûna nedilxwaz dûr bikevin, dîsa bi karanîna kargêriya peldankê ya lihevhatî bikar bînin.
Li vir mînakek xweşkirina tora Bootstrap li xala veqetandinê ya mezin ( lg
) û jorîn heye. Me .col
peldank .px-lg-5
bi . .mx-lg-n5
_ .row
_ .container
_.px-lg-5
Alignment
Karûbarên lihevkirina flexbox bikar bînin da ku stûnên vertîkal û horizontî li hev bikin. Internet Explorer 10-11 dema ku konteynera flex min-height
wekî ku li jêr tê xuyang kirin hebe hevrêzkirina vertîkal a hêmanên nerm piştgirî nake. Ji bo bêtir agahdarî li Flexbugs #3 bibînin.
Alignment Vertical
Alignment Horizontal
Ne gemar
Kevirên di navbera stûnan de di çînên meya tora meya pêşwext de dikarin bi .no-gutters
. margin
Ev s -yên neyînî .row
û horizontî padding
ji hemî stûnên zarokan ên yekser radike.
Li vir koda çavkaniyê ji bo afirandina van şêwazan e. Bala xwe bidinê ku guheztinên stûnê tenê li stûnên zarokan ên yekem têne veguheztin û bi rêya hilbijêra taybetmendiyê têne armanc kirin . Digel ku ev hilbijarkek taybetîtir çêdike, lêdana stûnê hîn jî dikare bi karûbarên valahiyê re bêtir were xweş kirin .
Pêdivî ye ku sêwiranek qev-bi-qewim? Dêûbav .container
an bavêjin .container-fluid
.
Di pratîkê de, li vir çawa xuya dike. Têbînî ku hûn dikarin vê yekê bi hemî dersên torê yên pêşwextkirî yên din re bikar bînin (tevî firehiyên stûnê, rêzikên bersivdar, ji nû ve rêzkirin, û hêj bêtir).
Pêçandina stûnê
Ger ji 12 stûnan zêdetir di nav rêzek yekane de werin danîn, her komek stûnên zêde dê, wekî yekînek, li ser rêzek nû biqelişe.
Ji ber ku 9 + 4 = 13 > 12, ev div-berfirehiya 4 stûnan li ser xeteke nû wekî yekînek hevgirtî tê pêçandin.
paşîn li ser xeta nû berdewam dikin.
Stûn diqete
Şikandina stûnan ji rêzek nû ya di flexbox de hackek piçûk hewce dike: li ku width: 100%
derê hûn dixwazin stûnên xwe li xêzek nû biqewirînin hêmanek zêde bikin. Bi gelemperî ev bi gelek .row
s pêk tê, lê her rêbazek pêkanînê nikare vê yekê hesab bike.
Her weha hûn dikarin vê veqetandinê li ser xalên veqetandinê yên taybetî bi karûbarên meya nîşana bersivdar bicîh bikin .
Reordering
Siparîşa çînên
Ji .order-
bo kontrolkirina rêzika dîtbarî ya naveroka xwe ders bikar bînin. Van ders bersivdar in, ji ber vê yekê hûn dikarin xala veqetandinê destnîşan bikin order
(mînak, .order-1.order-md-2
). Piştgiriya ji bo 1
her 12
pênc rêzikên torê vedihewîne.
Di heman demê de bersivdar .order-first
û .order-last
çînên ku bi rêzdarî order
bi sepandin order: -1
û order: 13
( order: $columns + 1
), hêmanekê diguherînin hene. .order-*
Li gorî hewcedariyê, ev çîn dikarin bi çînên hejmarkirî re jî werin tevlihev kirin .
Stûnên jihevdexistin
Hûn dikarin stûnên torê bi du awayan veqetînin: .offset-
dersên torê yên bersivdar û karûbarên me yên marjînal . Çînên torê têne mezin kirin ku stûnan li hev bikin dema ku marjînal ji bo sêwiranên bilez ên ku firehiya veqetandinê guhêrbar e bikêrtir in.
Dersên Offset
Bi karanîna dersan stûnan ber bi rastê ve .offset-md-*
bigerînin. Van dersan marjîna çepê ya stûnê bi *
stûnan zêde dikin. Mînakî, .offset-md-4
li .col-md-4
ser çar stûnan digere.
Ji bilî paqijkirina stûnê li nuqteyên veqetandî yên bersivdar, dibe ku hûn hewce ne ku guheztinan ji nû ve bikin. Vê di çalakiyê de di mînaka torê de bibînin .
Utilities Margin
Bi çûyîna flexbox-ê di v4 de, hûn dikarin karûbarên marjînal bikar bînin mîna .mr-auto
ku stûnên xwişk û birayên xwe ji hev dûr bikin.
Nesting
Ji bo ku hûn naveroka xwe bi tora xwerû re nehêlin, di nav stûnek heyî de stûnek nû .row
û komeke zêde bikin . Rêzên hêlînkirî divê komek stûnên ku ji 12 an kêmtir zêde dibin tê de bin (ne hewce ye ku hûn hemî 12 stûnên berdest bikar bînin)..col-sm-*
.col-sm-*
Sass tevlihev dikin
When using Bootstrap’s source Sass files, you have the option of using Sass variables and mixins to create custom, semantic, and responsive page layouts. Our predefined grid classes use these same variables and mixins to provide a whole suite of ready-to-use classes for fast responsive layouts.
Variables
Variables and maps determine the number of columns, the gutter width, and the media query point at which to begin floating columns. We use these to generate the predefined grid classes documented above, as well as for the custom mixins listed below.
Mixins
Mixins are used in conjunction with the grid variables to generate semantic CSS for individual grid columns.
Example usage
You can modify the variables to your own custom values, or just use the mixins with their default values. Here’s an example of using the default settings to create a two-column layout with a gap between.
Customizing the grid
Using our built-in grid Sass variables and maps, it’s possible to completely customize the predefined grid classes. Change the number of tiers, the media query dimensions, and the container widths—then recompile.
Columns and gutters
The number of grid columns can be modified via Sass variables. $grid-columns
is used to generate the widths (in percent) of each individual column while $grid-gutter-width
sets the width for the column gutters.
Grid tiers
Ji stûnan bi xwe re derbas bibin, hûn dikarin hejmara rêzikên torê jî xweş bikin. Ger we tenê çar qatên torê dixwest, hûn ê nûve bikin $grid-breakpoints
û bi vî rengî nûve bikin $container-max-widths
:
Dema ku hûn guhartinan li guhêrbar an nexşeyên Sass-ê bikin, hûn hewce ne ku guheztinên xwe hilînin û ji nû ve berhev bikin. Bi kirina vê yekê dê komek nû ya çînên torê yên pêşwextkirî ji bo firehiyên stûn, veqetandin, û rêzkirinê derxe. Karûbarên xuyangiya bersivdar jî dê werin nûve kirin da ku xalên veqetandinê yên xwerû bikar bînin. Bawer bikin ku nirxên torê di nav px
(ne rem
, em
, an %
) de bicîh bikin.