Сүлжээний систем
Арван хоёр баганын систем, өгөгдмөл хариу үйлдэл үзүүлэх таван шатлал, Sass хувьсагч болон холимгууд, мөн урьдчилан тодорхойлсон олон арван ангиудын ачаар бүх хэлбэр, хэмжээтэй бүдүүвчийг бүтээхийн тулд манай хүчирхэг гар утасны анхны флексбокс сүлжээг ашиглана уу.
Хэрхэн ажилладаг
Bootstrap-ийн сүлжээ систем нь агуулгыг байрлуулах, зэрэгцүүлэхийн тулд хэд хэдэн контейнер, мөр, баганыг ашигладаг. Энэ нь flexbox -оор бүтээгдсэн бөгөөд бүрэн хариу үйлдэл үзүүлдэг. Доорх нь жишээ бөгөөд сүлжээ хэрхэн нийлдэгийг нарийвчлан авч үзэх болно.
Flexbox-т шинээр орсон уу эсвэл мэдэхгүй байна уу? Энэхүү CSS Tricks flexbox гарын авлагаас суурь, нэр томьёо, заавар, кодын хэсгүүдийг уншина уу.
Дээрх жишээ нь бидний урьдчилан тодорхойлсон сүлжээний ангиудыг ашиглан жижиг, дунд, том, хэт том төхөөрөмжүүд дээр тэнцүү өргөнтэй гурван багана үүсгэдэг. Эдгээр баганууд нь хуудасны голд эцэг эхтэй .container
байна.
Үүнийг задалж үзвэл энэ нь хэрхэн ажилладаг вэ:
- Контейнер нь таны сайтын агуулгыг голчлох, хэвтээ байдлаар байрлуулах боломжийг олгодог.
.container
Хариуцлагатай пикселийн өргөн эсвэл бүх.container-fluid
харахwidth: 100%
хэсэг болон төхөөрөмжийн хэмжээст ашиглах . - Мөр нь баганын боодол юм. Багана бүр нь
padding
тэдгээрийн хоорондох зайг хянах зориулалттай хэвтээ (суваг гэж нэрлэдэг) байдаг. Дарааpadding
нь сөрөг зайтай мөрүүдэд үүнийг эсэргүүцнэ. Ингэснээр таны баганууд дахь бүх агуулгыг зүүн талд нь харагдах байдлаар байрлуулна. - Сүлжээний байршилд агуулгыг баганын дотор байрлуулах ёстой бөгөөд зөвхөн баганууд нь мөрийн шууд хүүхэд байж болно.
- Flexbox-ийн ачаар тодорхойгүй сүлжээ баганууд
width
автоматаар ижил өргөнтэй багана хэлбэрээр байрлуулна. Жишээ нь,.col-sm
will-ийн дөрвөн тохиолдол тус бүр нь автоматаар жижиг таслах цэгээс 25% ба түүнээс дээш өргөнтэй байна. Бусад жишээг автоматаар байрлуулах багана хэсгээс үзнэ үү . - Баганын ангиуд нь мөр бүрт боломжит 12 баганаас ашиглахыг хүсэж буй баганын тоог заана. Тиймээс, хэрэв та ижил өргөнтэй гурван багана авахыг хүсвэл -г ашиглаж болно
.col-4
. - Багана
width
s-ийг хувиар тогтоосон тул үндсэн элементтэйгээ харьцуулахад үргэлж шингэн, хэмжээтэй байдаг. padding
Баганууд нь бие даасан баганын хооронд суваг үүсгэхийн тулд хэвтээ байрлалтай байдаг. Гэхдээ таmargin
мөр болонpadding
баганаас.no-gutters
дээр байгаа мөрүүдийг устгаж болно.row
.- Сүлжээг хариу үйлдэл үзүүлэхийн тулд бүх таслах цэгүүд (илүү жижиг), жижиг, дунд, том, хэт том гэсэн таван сүлжээ таслах цэг байдаг .
- Сүлжээний таслах цэгүүд нь хамгийн бага өргөнтэй медиа асуулгад суурилдаг бөгөөд энэ нь тухайн нэг таслах цэг болон түүнээс дээш байгаа бүх зүйлд хамаарна (жишээ нь,
.col-sm-4
жижиг, дунд, том, хэт том төхөөрөмжүүдэд хамаарах боловч эхнийxs
таслах цэг биш). - Та илүү семантик тэмдэглэгээ хийхийн тулд урьдчилан тодорхойлсон сүлжээний ангиуд ( гэх мэт
.col-4
) эсвэл Sass хольцыг ашиглаж болно.
Зарим HTML элементүүдийг уян хатан контейнер болгон ашиглах боломжгүй гэх мэт flexbox - ийн хязгаарлалт, алдаануудыг мэдэж аваарай .
Сүлжээний сонголтууд
Bootstrap нь ихэнх хэмжээг тодорхойлохдоо em
s эсвэл s-г ашигладаг бол s нь сүлжээний таслах цэг болон савны өргөнд ашиглагддаг. Учир нь харах талбарын өргөн нь пикселээр илэрхийлэгдэх бөгөөд үсгийн хэмжээнээс хамаарч өөрчлөгддөггүй .rem
px
Bootstrap сүлжээний системийн талууд олон төхөөрөмж дээр хэрхэн ажилладагийг хялбар хүснэгтээр хараарай.
Хэт жижиг <576px |
Жижиг ≥576px |
Дунд зэргийн ≥768px |
Том ≥992px |
Хэт том ≥1200px |
|
---|---|---|---|---|---|
Хамгийн их савны өргөн | Байхгүй (автомат) | 540px | 720px | 960px | 1140px |
Ангийн угтвар | .col- |
.col-sm- |
.col-md- |
.col-lg- |
.col-xl- |
# багана | 12 | ||||
Сувагны өргөн | 30px (баганын тал бүр дээр 15px) | ||||
Суурин | Тиймээ | ||||
Баганын захиалга | Тиймээ |
Багануудыг автоматаар байрлуулах
гэх мэт тодорхой дугаарлагдсан ангигүйгээр баганын хэмжээг хялбар болгохын тулд таслах цэгийн тусгай баганын ангиудыг ашиглаарай .col-sm-6
.
Тэнцүү өргөн
Жишээ нь, эндээс эхлэн төхөөрөмж болон харах хэсэг болгонд хамаарах хоёр сүлжээний схем xs
байна xl
. Шаардлагатай таслах цэг бүрт хэдэн ч нэгж бага анги нэмэх ба багана бүр ижил өргөнтэй байх болно.
Тэнцүү өргөнтэй баганыг олон мөрөнд хувааж болох боловч Safari flexbox алдаа гарсан бөгөөд энэ нь тодорхой flex-basis
эсвэл border
. Хөтчийн хуучин хувилбаруудыг шийдвэрлэх арга замууд байдаг ч хэрэв та шинэчлэгдсэн бол тэдгээр нь шаардлагагүй.
Нэг баганын өргөнийг тохируулах
Flexbox сүлжээ баганын автомат байрлал нь нэг баганын өргөнийг тохируулж, дүүгийн баганын хэмжээг автоматаар өөрчлөх боломжтой гэсэн үг юм. Та урьдчилан тодорхойлсон сүлжээний ангиуд (доор үзүүлсэн шиг), сүлжээний холимог эсвэл шугамын өргөнийг ашиглаж болно. Төв баганын өргөнөөс үл хамааран бусад баганын хэмжээг өөрчлөх болно гэдгийг анхаарна уу.
Хувьсах өргөнтэй агуулга
Ангиудыг ашиглан col-{breakpoint}-auto
багануудыг агуулгынх нь байгалийн өргөнд тулгуурлан хэмжээлээрэй.
Тэнцүү өргөнтэй олон эгнээ
.w-100
Та баганыг таслахыг хүссэн газраа шинэ мөр болгон оруулж олон мөрийг хамарсан тэнцүү өргөнтэй багануудыг үүсгээрэй . .w-100
Зарим мэдрэгчтэй дэлгэцийн хэрэгслүүдтэй хольж завсарлагаа хариу үйлдэл үзүүлнэ үү .
Хариуцлагатай ангиуд
Bootstrap-ийн сүлжээнд нарийн төвөгтэй responsive зохион байгуулалтыг бий болгох урьдчилан тодорхойлсон таван түвшний анги багтдаг. Хэт жижиг, жижиг, дунд, том, эсвэл хэт том төхөөрөмжүүд дээр багануудынхаа хэмжээг өөрт тохирсон байдлаар тохируулаарай.
Бүх таслах цэгүүд
Хамгийн жижиг төхөөрөмжөөс хамгийн том хүртэл ижил сүлжээний хувьд .col
болон .col-*
ангиллыг ашиглана уу. Онцгой хэмжээтэй багана хэрэгтэй үед дугаарласан анги зааж өгөх; Хэрэв тийм биш бол, -г бүү зөвшөөр .col
.
Хэвтээ чиглэлд давхарласан
Нэг багц .col-sm-*
ангиудыг ашигласнаар та овоолсон байдлаар эхэлж, жижиг таслах цэг ( sm
) дээр хэвтээ болдог үндсэн сүлжээний системийг үүсгэж болно.
Хольж, тааруулна
Таны баганууд зүгээр л сүлжээний хэд хэдэн шатлалд овоолсон байхыг хүсэхгүй байна уу? Шаардлагатай бол шат бүрт өөр өөр ангиудын хослолыг ашиглана уу. Энэ бүхэн хэрхэн ажилладаг талаар илүү сайн ойлголт авахын тулд доорх жишээг үзнэ үү.
Суваг
Сувагуудыг таслах цэгийн тусгай дэвсгэр болон сөрөг ахиуц хэрэглээний ангиудын тусламжтайгаар тохируулж болно. Өгөгдсөн эгнээний сувгийг өөрчлөхийн тулд сөрөг маржин хэрэглүүрийг s .row
дээр, тохирох дүүргэгч хэрэгслийг хослуулна уу .col
. Дахин тохирох padding хэрэгслийг ашиглан хүсээгүй халилтаас зайлсхийхийн тулд .container
эсвэл .container-fluid
эцэг эхийг тохируулах шаардлагатай байж магадгүй.
lg
Bootstrap сүлжээг том ( ) ба түүнээс дээш цэгт тохируулах жишээ энд байна. Бид .col
дэвсгэрийг -ээр нэмэгдүүлж, эцэг эх дээр нь үүнийг .px-lg-5
эсэргүүцэж , дараа нь боодлыг -аар тохируулсан ..mx-lg-n5
.row
.container
.px-lg-5
Тохируулга
Багануудыг босоо болон хэвтээ байдлаар зэрэгцүүлэхийн тулд flexbox alignment хэрэгслийг ашиглана уу.
Босоо зэрэгцүүлэх
Хэвтээ зэрэгцүүлэх
Ус зайлуулах суваг байхгүй
Урьдчилан тодорхойлсон сүлжээ ангиудын баганын хоорондох сувгийг ашиглан арилгаж болно .no-gutters
. Энэ нь бүх шууд хүүхдийн баганаас сөрөг margin
s .row
, хэвтээ баганаас хасагдана.padding
Эдгээр хэв маягийг бий болгох эх код энд байна. Баганыг дарах нь зөвхөн эхний хүүхэд баганад хамаарах бөгөөд шинж чанар сонгогчоор чиглэгддэг гэдгийг анхаарна уу . Энэ нь илүү тодорхой сонгогчийг үүсгэдэг ч багана дүүргэлтийг зайны хэрэгслүүдээр өөрчлөх боломжтой хэвээр байна .
Ирмэгээс ирмэг хүртэл загвар хэрэгтэй юу? Эцэг эхийг орхих .container
эсвэл .container-fluid
.
Практик дээр энэ нь хэрхэн харагдахыг эндээс харна уу. Та үүнийг бусад бүх урьдчилан тодорхойлсон сүлжээ ангиудад (баганын өргөн, хариу үйлдэл үзүүлэх түвшин, дахин эрэмбэлэх гэх мэт) үргэлжлүүлэн ашиглах боломжтойг анхаарна уу.
Багана боох
Хэрэв нэг мөрөнд 12-оос дээш багана байрлуулсан бол нэмэлт баганын бүлэг бүрийг нэг нэгж болгон шинэ мөрөнд оруулна.
9 + 4 = 13 > 12 тул энэ 4 баганын өргөнтэй div нь шинэ мөрөнд нэг залгаа нэгж хэлбэрээр ороогдоно.
Дараагийн баганууд шинэ мөрийн дагуу үргэлжилнэ.
Багана тасарсан
Flexbox дахь багануудыг шинэ мөрөнд эвдэхийн тулд жижиг хакердах шаардлагатай: шинэ мөрөнд баганаа боохыг width: 100%
хүссэн газартаа элемент нэмнэ үү. Энэ нь ихэвчлэн олон секундын тусламжтайгаар хийгддэг .row
боловч хэрэгжүүлэх арга бүр үүнийг тооцоолж чаддаггүй.
Та энэ завсарлагыг манай мэдрэгчтэй дэлгэцийн хэрэгслүүдээр тодорхой таслах цэгүүдэд хэрэглэж болно .
Дахин эрэмбэлж байна
Ангиудыг захиалах
Агуулгынхаа харааны дарааллыг.order-
хянахын тулд ангиудыг ашиглаарай . Эдгээр ангиуд нь хариу үйлдэл үзүүлдэг тул та таслах цэгээр (жишээ нь, ) тохируулах боломжтой. Бүх таван сүлжээний түвшний дэмжлэгийг багтаасан болно .order
.order-1.order-md-2
1
12
Мөн ( )-ийг тус тус хэрэглэснээр элементийн хэлбэрийг өөрчилдөг responsive .order-first
болон ангиуд байдаг. Шаардлагатай бол эдгээр ангиудыг дугаарлагдсан ангиудтай хольж болно ..order-last
order
order: -1
order: 13
order: $columns + 1
.order-*
Багануудыг нөхөх
Та сүлжээний баганыг хоёр аргаар нөхөж болно: бидний хариу үйлдэл .offset-
үзүүлэх сүлжээний ангиуд болон манай margin utilities . Сүлжээний ангиудын хэмжээ нь баганатай таарч байхын зэрэгцээ офсетийн өргөн нь хувьсах боломжтой тохиолдолд захын зай нь илүү ашигтай байдаг.
Офсет ангиуд
Ангиудыг ашиглан багануудыг баруун тийш зөөнө үү .offset-md-*
. Эдгээр ангиуд нь баганын зүүн захыг *
баганаар нэмэгдүүлнэ. Жишээлбэл, дөрвөн багана дээр .offset-md-4
шилжинэ ..col-md-4
Хариуцах цэгүүд дээр баганыг цэвэрлэхээс гадна офсетийг дахин тохируулах шаардлагатай байж магадгүй. Сүлжээний жишээн дээрх үйлдлийг харна уу .
Margin хэрэгслүүд
V4-ийн flexbox руу шилжсэнээр та .mr-auto
ах дүү багануудыг бие биенээсээ холдуулах гэх мэт маржин хэрэгслүүдийг ашиглаж болно.
Үүрлэх
Өөрийн агуулгыг өгөгдмөл сүлжээнд оруулахын тулд одоо байгаа баганад шинэ .row
ба багц багана нэмнэ үү. Суурилуулсан мөрүүд нь 12 ба түүнээс цөөн тооны багануудыг багтаасан байх ёстой (энэ нь та боломжтой бүх 12 баганыг ашиглах шаардлагагүй)..col-sm-*
.col-sm-*
Сасс холимог
Bootstrap-ийн эх сурвалж Sass файлуудыг ашиглах үед та Sass хувьсагч болон холимогийг ашиглан захиалгат, семантик, хариу үйлдэл үзүүлэх хуудасны байршлыг үүсгэх боломжтой. Манай урьдчилан тодорхойлсон сүлжээний ангиуд нь эдгээр ижил хувьсагч болон холимгуудыг ашиглан хурдан хариу үйлдэл үзүүлэхэд зориулагдсан ашиглахад бэлэн ангиудыг бүрэн хангадаг.
Хувьсагч
Хувьсагч ба газрын зураг нь баганын тоо, сувгийн өргөн, хөвөгч баганыг эхлүүлэх медиа асуулгын цэгийг тодорхойлдог. Бид эдгээрийг дээр дурдсан урьдчилан тодорхойлсон сүлжээний ангиудыг үүсгэхийн зэрэгцээ доор жагсаасан захиалгат хольцуудад ашигладаг.
Холимог
Холимогуудыг сүлжээний хувьсагчтай хамт тус тусад нь сүлжээ баганын семантик CSS үүсгэхэд ашигладаг.
Хэрэглээний жишээ
Та хувьсагчдыг өөрийн тохируулсан утгуудаар өөрчилж болно, эсвэл зүгээр л үндсэн утгуудынх нь хамт холимогийг ашиглаж болно. Үндсэн тохиргоог ашиглан хоёр баганын хоорондох зайг бий болгох жишээ энд байна.
Сүлжээг тохируулах
Бидний суулгасан сүлжээний Sass хувьсагч болон газрын зургийг ашиглан урьдчилан тодорхойлсон сүлжээний ангиудыг бүрэн өөрчлөх боломжтой. Давхаргын тоо, медиа асуулгын хэмжээ, савны өргөнийг өөрчилсний дараа дахин эмхэтгэ.
Багана ба суваг
Сүлжээний баганын тоог Sass хувьсагчаар өөрчилж болно. $grid-columns
нь багана тус бүрийн өргөнийг (хувиар) үүсгэхийн зэрэгцээ $grid-gutter-width
баганын сувгийн өргөнийг тохируулахад ашиглагддаг.
Сүлжээний давхарга
Багануудыг өөрсдөөсөө цааш хөдөлж, та сүлжээний түвшний тоог өөрчлөх боломжтой. Хэрэв та ердөө дөрвөн шатлалтай байхыг хүсвэл " $grid-breakpoints
and "-г дараах байдлаар шинэчлэх болно $container-max-widths
:
Sass хувьсагч эсвэл газрын зурагт өөрчлөлт оруулахдаа та өөрчлөлтөө хадгалж, дахин эмхэтгэх шаардлагатай. Үүнийг хийснээр баганын өргөн, офсет болон дарааллын хувьд урьдчилан тодорхойлсон сүлжээ ангиудын цоо шинэ багц гарч ирнэ. Хариуцлагатай харагдах байдлын хэрэгслүүд мөн өөрчлөн тохируулсан цэгүүдийг ашиглахын тулд шинэчлэгдэх болно. px
Сүлжээний утгыг ( rem
, em
, эсвэл биш) тохируулахаа мартуузай %
.