css властивість grid-area
Властивість grid-area
- це універсальна властивість, для скороченого запису:
grid-row-start
(задає першу горизонтальну лінію для елемента)grid-column-start
(задає першу вертикальну лінію для елемента)*grid-row-end
(задає останню горизонтальну лінію для елемента)grid-column-end
(задає останню вертикальну лінію для елемента)
Цими властивостями ми визначаємо область, в яку буде поміщений елемент. Вони дозволяють вказати, де рядок починається на сітці та скільки клітинок він охоплює. Для цього використовуються номери ліній. Початкове значення цих властивостей - auto
, завдяки чому елементи можуть розміщуватися автоматично, відшукуючи у сітці порожні клітинки.
За допомогою grid-area
, ми можемо записати всі ці чотири властивості одночасно. Наприклад:
.box {
grid-column-start: 2;
grid-column-end: 4;
grid-row-start: 2;
grid-row-end 4;
}
А можна записати так:
.box {
grid-area: 2 / 2 / 4 / 4;
}
Записуємо саме в цій послідовності: grid-row-start / grid-column-start / grid-row-end / grid-column-end
. Риска (/) відділяє значення для кожної під-властивості.
Також властивість grid-area
можна використовувати, щоб дати елементу ім'я, щоб на нього міг посилатися шаблон, створений за допомогою властивості grid-template-areas
:
/* тут визначаємо імена */
grid-template-areas:
"a b c"
"d e f"
"g h i";
/* посилаємося на імена з сітки */
.box .item:first-child {
grid-area: e / e / i / i;
}
Неявні іменовані лінії
Ви також можете посилатися на будь-які неявні (і явні) названі лінії, які були визначені в сітці.
Неявні названі рядки створюються автоматично, коли ви створюєте іменовану сітку. Тому, коли ви створюєте імена для елементів сітки (як у попередньому прикладі), за цим сценарієм створюється цілий набір імпліцитних (невиражених) названих рядків.
Для кожної названої сіткової області з ім'ям, наприклад foo
створюються чотири імпліцитно названі рядки. Два імені, що називаються foo-start
, називаються рядками початку рядка і стовпця та двома імені foo-end
називаються рядками кінці рядка і стовпця.
Отже, ми можемо взяти приклад вище і додати -start
для обох значень e
і -end
до обох i значень, і матимемо імпліцитні названі рядки:
/* тут визначаємо імена */
grid-template-areas:
"a b c"
"d e f"
"g h i";
/* посилаємося на неявні іменовані рядки */
.box .item:first-child {
grid-area: e-start / e-start / i-end / i-end;
}
Отже, ми фактично не визначали e-start
або i-end
в будь-якому місці коду. Вони були автоматично створені з наших названих областей сітки. Якщо б ми назвали ці області, скажімо, one
і two
, наші неявні названі рядки будуть називатися one-start
і two-end
.
Явні іменовані рядки
CSS також дозволяє вказати власні імена для ліній сітки. Вони називаються явними названими рядками. Ви можете створювати ці імена, коли ви визначаєте клітинки, а потім звертаєтесь до них, як з неявними названими рядками:
/* визначаємо рідки й імена ліній */
grid-template-columns: 1fr [col2-start] 1fr 1fr [col3-end];
grid-template-rows: 1fr [row2-start] 1fr 1fr [row3-end] 1fr;
/* посилаємося на іменовані рядки */
#grid >` div:first-child {
grid-area: row2-start / col2-start / row3-end / col3-end;
}
Ключове слово span
Ключове слово span
може використовуватися для того, щоб елемент сітки міг послідовно поєднувати кілька клітин.
Ось результат використання span
:
Синтаксис
grid-area: <name> | <row-start> / <column-start> / <row-end> / <column-end>;
Властивість grid-area може отримувати 2 значення:
<name>
Ім'я для елемента сітки.
<row-start> / <column-start> / <row-end> / <column-end>
Значення для під-властивостей
grid-row-start
,grid-column-start
,grid-row-end
,grid-column-end
відповідно.
Значення без задання: | auto |
---|---|
Наслідує: | Ні |
Анімується: | Так |
JavaScript синтаксис: | object.style.gridArea |
Переглядачі
Переглядач | ||||||
---|---|---|---|---|---|---|
grid-area | 57.0 |
Не підтримується |
52.0 |
10.1 |
44.0 |
16.0 |
Переглядач | |||
---|---|---|---|
grid-area | 57.0 |
52.0 |
10.3 |
Мобільних переглядачів ще не додано.
Приклади
Динамічний приклад роботи властивості
Універсальна властивість
Ключове слово span
Синтаксис
.box {
grid-area: 1 / 2/ 1 / 6;
}
Синтаксис
.box {
grid-area: header;
}