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