Сүлжээний систем
Арван хоёр баганын систем, зургаан өгөгдмөл хариу үйлдэл үзүүлэх шатлал, Sass хувьсагч болон холимог болон олон арван урьдчилан тодорхойлсон ангиудын ачаар бүх хэлбэр, хэмжээтэй бүдүүвчийг бүтээхийн тулд гар утасны анхны флексбокс сүлжээг ашиглана уу.
Жишээ
Bootstrap-ийн сүлжээ систем нь агуулгыг байрлуулах, зэрэгцүүлэхийн тулд хэд хэдэн контейнер, мөр, баганыг ашигладаг. Энэ нь flexbox -оор бүтээгдсэн бөгөөд бүрэн хариу үйлдэл үзүүлдэг. Сүлжээний систем хэрхэн нийлдэг талаар жишээ болон дэлгэрэнгүй тайлбарыг доор харуулав.
<div class="container">
<div class="row">
<div class="col">
Column
</div>
<div class="col">
Column
</div>
<div class="col">
Column
</div>
</div>
</div>
Дээрх жишээ нь бидний урьдчилан тодорхойлсон сүлжээний ангиудыг ашиглан бүх төхөөрөмж болон харах хэсэгт ижил өргөнтэй гурван багана үүсгэдэг. Эдгээр баганууд нь хуудасны голд эцэг эхтэй .container
байна.
Хэрхэн ажилладаг
Үүнийг задалж үзвэл, сүлжээний систем хэрхэн нэгддэг:
-
Манай сүлжээ нь хариу үйлдэл үзүүлэх зургаан цэгийг дэмждэг . Хугарлын цэгүүд нь медиа асуулгад суурилдаг бөгөөд
min-width
энэ нь тухайн таслах цэг болон түүнээс дээш байгаа бүх зүйлд нөлөөлдөг (жишээ нь: , , , , болон -д.col-sm-4
хамаарна ). Энэ нь та таслах цэг тус бүрээр контейнер болон баганын хэмжээ, үйлдлийг хянах боломжтой гэсэн үг юм.sm
md
lg
xl
xxl
-
Контейныг голлон байрлуулж, контентоо хэвтээ байдлаар байрлуулна. Бүх харагдац болон төхөөрөмжүүдэд мэдрэгчтэй
.container
пикселийн өргөн, эсвэл шингэн болон пикселийн өргөнийг хослуулахад хариу үйлдэл үзүүлэх сав (жишээ нь, ) ашиглах боломжтой..container-fluid
width: 100%
.container-md
-
Мөр нь баганын боодол юм. Багана бүр нь
padding
тэдгээрийн хоорондох зайг хянах зориулалттай хэвтээ (суваг гэж нэрлэдэг) байдаг. Дарааpadding
нь таны баганууд дахь агуулгыг зүүн талдаа нүдээр зэрэгцүүлэхийн тулд сөрөг зайтай мөрүүдэд үүнийг эсэргүүцнэ. Мөрүүд нь баганын хэмжээсийг жигд хэрэглэхийн тулд өөрчлөгч ангиудыг дэмжинэ , агуулгынхаа зайг өөрчлөхийн тулд сувгийн ангиллыг жигдрүүлнэ. -
Баганууд нь гайхалтай уян хатан байдаг. Нэг мөрөнд 12 загвар багана байдаг бөгөөд энэ нь танд ямар ч тооны багануудыг хамарсан өөр өөр элементүүдийн хослолыг үүсгэх боломжийг олгоно. Баганын ангиуд нь дамжих загвар баганын тоог заадаг (жишээ нь,
col-4
дөрөв хүртэлх).width
s-ийг хувиар тогтоосон тул та үргэлж ижил хэмжээтэй байх болно. -
Суваг нь бас хариу үйлдэл үзүүлэх чадвартай бөгөөд өөрчлөх боломжтой. Сувагны ангиуд нь манай захын зай болон дүүргэх зайтай ижил хэмжээтэй, бүх таслах цэгүүдэд байдаг.
.gx-*
Хэвтээ сувгийг ангитай, босоо суваг шуудууг -тэй.gy-*
, эсвэл бүх суваг шуудууг ангитай өөрчил.g-*
..g-0
мөн суваг зайлуулах боломжтой. -
Sass хувьсагч, газрын зураг, холимог нь сүлжээг тэжээдэг. Хэрэв та Bootstrap-д урьдчилан тодорхойлсон grid ангиудыг ашиглахыг хүсэхгүй байгаа бол манай сүлжээний эх сурвалж Sass -ийг ашиглан илүү семантик тэмдэглэгээг ашиглан өөрийн гараар үүсгэж болно. Мөн бид танд илүү уян хатан болгох үүднээс эдгээр Sass хувьсагчдыг ашиглахын тулд CSS-ийн захиалгат шинж чанаруудыг багтаасан болно.
Зарим HTML элементүүдийг уян хатан контейнер болгон ашиглах боломжгүй гэх мэт flexbox - ийн хязгаарлалт, алдаануудыг мэдэж аваарай .
Сүлжээний сонголтууд
Bootstrap-ийн сүлжээ систем нь бүх зургаан өгөгдмөл таслах цэг болон таны тохируулсан аливаа таслах цэгүүдэд дасан зохицож чаддаг. Зургаан үндсэн сүлжээний шат нь дараах байдалтай байна.
- Хэт жижиг (xs)
- Жижиг (см)
- Дунд (md)
- Том (lg)
- Хэт том (xl)
- Хэт том (xxl)
Дээр дурдсанчлан, эдгээр таслах цэг бүр өөрийн гэсэн контейнер, өвөрмөц ангийн угтвар, өөрчлөгчтэй байдаг. Эдгээр таслах цэгүүдэд сүлжээ хэрхэн өөрчлөгдөхийг эндээс үзнэ үү:
xs <576px |
см ≥576px |
md ≥768px |
lg ≥992px |
xl ≥1200px |
xxl ≥1400px |
|
---|---|---|---|---|---|---|
Контейнерmax-width |
Байхгүй (автомат) | 540px | 720px | 960px | 1140px | 1320px |
Ангийн угтвар | .col- |
.col-sm- |
.col-md- |
.col-lg- |
.col-xl- |
.col-xxl- |
# багана | 12 | |||||
Сувагны өргөн | 1.5 рем (зүүн ба баруун талд .75 рем) | |||||
Захиалгат суваг | Тиймээ | |||||
Суурин | Тиймээ | |||||
Баганын захиалга | Тиймээ |
Багануудыг автоматаар байрлуулах
гэх мэт тодорхой дугаарлагдсан ангигүйгээр баганын хэмжээг хялбар болгохын тулд таслах цэгийн тусгай баганын ангиудыг ашиглаарай .col-sm-6
.
Тэнцүү өргөн
Жишээ нь, эндээс эхлэн төхөөрөмж болон харах хэсэг болгонд хамаарах хоёр сүлжээний схем xs
байна xxl
. Шаардлагатай таслах цэг бүрт хэдэн ч нэгж бага анги нэмэх ба багана бүр ижил өргөнтэй байх болно.
<div class="container">
<div class="row">
<div class="col">
1 of 2
</div>
<div class="col">
2 of 2
</div>
</div>
<div class="row">
<div class="col">
1 of 3
</div>
<div class="col">
2 of 3
</div>
<div class="col">
3 of 3
</div>
</div>
</div>
Нэг баганын өргөнийг тохируулах
Flexbox сүлжээ багануудыг автоматаар байрлуулснаар та нэг баганын өргөнийг тохируулж, ах дүү багануудын хэмжээг автоматаар өөрчлөх боломжтой гэсэн үг юм. Та урьдчилан тодорхойлсон сүлжээний ангиуд (доор үзүүлсэн шиг), сүлжээний холимог эсвэл шугамын өргөнийг ашиглаж болно. Төв баганын өргөнөөс үл хамааран бусад баганын хэмжээг өөрчлөх болно гэдгийг анхаарна уу.
<div class="container">
<div class="row">
<div class="col">
1 of 3
</div>
<div class="col-6">
2 of 3 (wider)
</div>
<div class="col">
3 of 3
</div>
</div>
<div class="row">
<div class="col">
1 of 3
</div>
<div class="col-5">
2 of 3 (wider)
</div>
<div class="col">
3 of 3
</div>
</div>
</div>
Хувьсах өргөнтэй агуулга
Ангиудыг ашиглан col-{breakpoint}-auto
багануудыг агуулгынх нь байгалийн өргөнд тулгуурлан хэмжээлээрэй.
<div class="container">
<div class="row justify-content-md-center">
<div class="col col-lg-2">
1 of 3
</div>
<div class="col-md-auto">
Variable width content
</div>
<div class="col col-lg-2">
3 of 3
</div>
</div>
<div class="row">
<div class="col">
1 of 3
</div>
<div class="col-md-auto">
Variable width content
</div>
<div class="col col-lg-2">
3 of 3
</div>
</div>
</div>
Хариуцлагатай ангиуд
Bootstrap-ийн сүлжээнд нарийн төвөгтэй responsive зохион байгуулалтыг бий болгохын тулд урьдчилан тодорхойлсон зургаан түвшний ангиуд багтдаг. Хэт жижиг, жижиг, дунд, том, эсвэл хэт том төхөөрөмжүүд дээр багануудынхаа хэмжээг өөрт тохирсон байдлаар тохируулаарай.
Бүх таслах цэгүүд
Хамгийн жижиг төхөөрөмжөөс хамгийн том хүртэл ижил сүлжээний хувьд .col
болон .col-*
ангиллыг ашиглана уу. Онцгой хэмжээтэй багана хэрэгтэй үед дугаарласан анги зааж өгөх; Хэрэв тийм биш бол, -г бүү зөвшөөр .col
.
<div class="container">
<div class="row">
<div class="col">col</div>
<div class="col">col</div>
<div class="col">col</div>
<div class="col">col</div>
</div>
<div class="row">
<div class="col-8">col-8</div>
<div class="col-4">col-4</div>
</div>
</div>
Хэвтээ чиглэлд давхарласан
Нэг багц .col-sm-*
ангиудыг ашигласнаар та овоолсон байдлаар эхэлж, жижиг таслах цэг ( sm
) дээр хэвтээ болдог үндсэн сүлжээний системийг үүсгэж болно.
<div class="container">
<div class="row">
<div class="col-sm-8">col-sm-8</div>
<div class="col-sm-4">col-sm-4</div>
</div>
<div class="row">
<div class="col-sm">col-sm</div>
<div class="col-sm">col-sm</div>
<div class="col-sm">col-sm</div>
</div>
</div>
Хольж, тааруулна
Таны баганууд зүгээр л зарим сүлжээний давхаргад овоолсон байхыг хүсэхгүй байна уу? Шаардлагатай бол шат бүрт өөр өөр ангиудын хослолыг ашиглана уу. Энэ бүхэн хэрхэн ажилладаг талаар илүү сайн санаа авахын тулд доорх жишээг үзнэ үү.
<div class="container">
<!-- Stack the columns on mobile by making one full-width and the other half-width -->
<div class="row">
<div class="col-md-8">.col-md-8</div>
<div class="col-6 col-md-4">.col-6 .col-md-4</div>
</div>
<!-- Columns start at 50% wide on mobile and bump up to 33.3% wide on desktop -->
<div class="row">
<div class="col-6 col-md-4">.col-6 .col-md-4</div>
<div class="col-6 col-md-4">.col-6 .col-md-4</div>
<div class="col-6 col-md-4">.col-6 .col-md-4</div>
</div>
<!-- Columns are always 50% wide, on mobile and desktop -->
<div class="row">
<div class="col-6">.col-6</div>
<div class="col-6">.col-6</div>
</div>
</div>
Мөр багана
.row-cols-*
Таны контент болон байршлыг хамгийн сайн харуулах баганын тоог хурдан тохируулахын тулд хариу үйлдэл үзүүлэх ангиудыг ашиглана уу. Хэвийн .col-*
ангиуд нь тус тусын баганад (жишээ нь, .col-md-4
) хамаарах бол мөрийн баганын ангиудыг .row
агуулагдсан баганын хувьд өгөгдмөл байдлаар эцэг эх дээр тохируулсан болно. Үүний тусламжтайгаар .row-cols-auto
багануудыг байгалийн өргөнөөр нь өгч болно.
Эдгээр мөрийн баганын ангиудыг ашиглан үндсэн сүлжээний бүдүүвчийг хурдан үүсгэх эсвэл картынхаа байршлыг хянах, шаардлагатай үед баганын түвшинд дарж бичих боломжтой.
<div class="container">
<div class="row row-cols-2">
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col">Column</div>
</div>
</div>
<div class="container">
<div class="row row-cols-3">
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col">Column</div>
</div>
</div>
<div class="container">
<div class="row row-cols-auto">
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col">Column</div>
</div>
</div>
<div class="container">
<div class="row row-cols-4">
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col">Column</div>
</div>
</div>
<div class="container">
<div class="row row-cols-4">
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col-6">Column</div>
<div class="col">Column</div>
</div>
</div>
<div class="container">
<div class="row row-cols-1 row-cols-sm-2 row-cols-md-4">
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col">Column</div>
</div>
</div>
<div class="container">
<div class="row row-cols-2 row-cols-lg-3">
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col">Column</div>
<div class="col-4 col-lg-2">Column</div>
<div class="col-4 col-lg-2">Column</div>
<div class="col-4 col-lg-2">Column</div>
<div class="col-4 col-lg-2">Column</div>
<div class="col-4 col-lg-2">Column</div>
<div class="col-4 col-lg-2">Column</div>
</div>
</div>
Та мөн дагалдах Sass хольцыг ашиглаж болно, row-cols()
:
.element {
// Three columns to start
@include row-cols(3);
// Five columns from medium breakpoint up
@include media-breakpoint-up(md) {
@include row-cols(5);
}
}
Үүрлэх
Өөрийн агуулгыг өгөгдмөл сүлжээнд оруулахын тулд одоо байгаа баганад шинэ .row
ба багц багана нэмнэ үү. Суурилуулсан мөрүүд нь 12 ба түүнээс цөөн тоог нэмэх баганын багцыг агуулсан байх ёстой (боломжтой бүх 12 баганыг ашиглах шаардлагагүй)..col-sm-*
.col-sm-*
<div class="container">
<div class="row">
<div class="col-sm-3">
Level 1: .col-sm-3
</div>
<div class="col-sm-9">
<div class="row">
<div class="col-8 col-sm-6">
Level 2: .col-8 .col-sm-6
</div>
<div class="col-4 col-sm-6">
Level 2: .col-4 .col-sm-6
</div>
</div>
</div>
</div>
</div>
Сасс
Bootstrap-ийн эх сурвалж Sass файлуудыг ашиглах үед та Sass хувьсагч болон холимогийг ашиглан захиалгат, семантик, хариу үйлдэл үзүүлэх хуудасны байршлыг үүсгэх боломжтой. Манай урьдчилан тодорхойлсон сүлжээний ангиуд нь эдгээр ижил хувьсагч болон холимгуудыг ашиглан хурдан хариу үйлдэл үзүүлэхэд зориулагдсан ашиглахад бэлэн ангиудыг бүрэн хангадаг.
Хувьсагч
Хувьсагч ба газрын зураг нь баганын тоо, сувгийн өргөн, хөвөгч баганыг эхлүүлэх медиа асуулгын цэгийг тодорхойлдог. Бид эдгээрийг дээр дурдсан урьдчилан тодорхойлсон сүлжээний ангиудыг үүсгэхийн зэрэгцээ доор жагсаасан захиалгат хольцуудад ашигладаг.
$grid-columns: 12;
$grid-gutter-width: 1.5rem;
$grid-breakpoints: (
xs: 0,
sm: 576px,
md: 768px,
lg: 992px,
xl: 1200px,
xxl: 1400px
);
$container-max-widths: (
sm: 540px,
md: 720px,
lg: 960px,
xl: 1140px,
xxl: 1320px
);
Холимог
Холимогуудыг сүлжээний хувьсагчтай хамт тус тусад нь сүлжээ баганын семантик CSS үүсгэхэд ашигладаг.
// Creates a wrapper for a series of columns
@include make-row();
// Make the element grid-ready (applying everything but the width)
@include make-col-ready();
// Without optional size values, the mixin will create equal columns (similar to using .col)
@include make-col();
@include make-col($size, $columns: $grid-columns);
// Get fancy by offsetting, or changing the sort order
@include make-col-offset($size, $columns: $grid-columns);
Хэрэглээний жишээ
Та хувьсагчдыг өөрийн тохируулсан утгуудаар өөрчилж болно, эсвэл зүгээр л үндсэн утгуудтай нь холигчдыг ашиглаж болно. Үндсэн тохиргоог ашиглан хоёр баганын хоорондох зайг бий болгох жишээ энд байна.
.example-container {
@include make-container();
// Make sure to define this width after the mixin to override
// `width: 100%` generated by `make-container()`
width: 800px;
}
.example-row {
@include make-row();
}
.example-content-main {
@include make-col-ready();
@include media-breakpoint-up(sm) {
@include make-col(6);
}
@include media-breakpoint-up(lg) {
@include make-col(8);
}
}
.example-content-secondary {
@include make-col-ready();
@include media-breakpoint-up(sm) {
@include make-col(6);
}
@include media-breakpoint-up(lg) {
@include make-col(4);
}
}
<div class="example-container">
<div class="example-row">
<div class="example-content-main">Main content</div>
<div class="example-content-secondary">Secondary content</div>
</div>
</div>
Сүлжээг тохируулах
Бидний суулгасан сүлжээний Sass хувьсагч болон газрын зургийг ашиглан урьдчилан тодорхойлсон сүлжээний ангиудыг бүрэн өөрчлөх боломжтой. Давхаргын тоо, медиа асуулгын хэмжээ, савны өргөнийг өөрчилсний дараа дахин эмхэтгэ.
Багана ба суваг
Сүлжээний баганын тоог Sass хувьсагчаар өөрчилж болно. $grid-columns
нь багана тус бүрийн өргөнийг (хувиар) үүсгэхийн зэрэгцээ $grid-gutter-width
баганын сувгийн өргөнийг тохируулахад ашиглагддаг.
$grid-columns: 12 !default;
$grid-gutter-width: 1.5rem !default;
Сүлжээний давхарга
Багануудыг өөрсдөөсөө цааш хөдөлж, та сүлжээний түвшний тоог тохируулах боломжтой. Хэрэв та ердөө дөрвөн шатлалтай байхыг хүсвэл " $grid-breakpoints
and "-г дараах байдлаар шинэчлэх болно $container-max-widths
:
$grid-breakpoints: (
xs: 0,
sm: 480px,
md: 768px,
lg: 1024px
);
$container-max-widths: (
sm: 420px,
md: 720px,
lg: 960px
);
Sass хувьсагч эсвэл газрын зурагт өөрчлөлт оруулахдаа та өөрчлөлтөө хадгалж, дахин эмхэтгэх шаардлагатай болно. Ингэснээр баганын өргөн, офсет болон дарааллаар урьдчилан тодорхойлсон сүлжээ ангиудын цоо шинэ багц гарч ирнэ. Хариуцлагатай харагдах байдлын хэрэгслүүд мөн өөрчлөн тохируулсан цэгүүдийг ашиглахын тулд шинэчлэгдэх болно. px
Сүлжээний утгыг ( rem
, em
, эсвэл биш) тохируулахаа мартуузай %
.