JS властивість CSSStyleDeclaration.flexBasis
Загальний опис
element.style.flexBasis – це властивість CSS, яку можна використовувати в JavaScript для встановлення або отримання значення початкового розміру гнучкого елементу. Ця властивість визначає основний розмір елемента до того, як він буде розподілений між іншими гнучкими елементами в контейнері.
Властивість flexBasis визначає, який простір має займати елемент у контейнері до застосування будь-яких інших стилів, таких як flexGrow або flexShrink. Це може бути вказано як конкретне значення (наприклад, в пікселях, відсотках тощо) або автоматично визначено за вмістом (auto).
Для роботи з element.style.flexBasis потрібно мати на увазі, що ця властивість доступна тільки для гнучких елементів, тобто тих, які знаходяться в контейнері з display: flex або display: inline-flex.
Приклад використання element.style.flexBasis
Встановлення значення
flexBasis:const element = document.getElementById('myElement'); element.style.flexBasis = '200px';У цьому прикладі ми отримуємо доступ до елемента з id
myElementі встановлюємо його початковий розмір у 200 пікселів.Отримання значення
flexBasis:const element = document.getElementById('myElement'); const flexBasisValue = element.style.flexBasis; console.log(flexBasisValue);Цей код отримує значення
flexBasisдля елемента і виводить його у консоль.
Важливі моменти
- Одиниці виміру: Значення
flexBasisможе бути встановлено в різних одиницях виміру, таких як пікселі (px), відсотки (%), ем (em), рем (rem) тощо. - Автоматичне значення: Якщо
flexBasisвстановлено вauto, то розмір елемента буде визначатися його вмістом або іншими стилями, такими якwidthабоheight.
Приклади
Використання з відсотками:
const element = document.getElementById('myElement');
element.style.flexBasis = '50%';
Цей приклад встановлює початковий розмір елемента як 50% від розміру контейнера.
Використання з автоматичним значенням:
const element = document.getElementById('myElement');
element.style.flexBasis = 'auto';
Встановлення flexBasis в auto дозволяє елементу визначати свій розмір автоматично на основі вмісту або інших стилів.
Загалом, властивість element.style.flexBasis є потужним інструментом для управління розмірами елементів у гнучкому контейнері, забезпечуючи гнучкість та контроль за розташуванням елементів у макеті.
| Порада: | Під час роботи з комплексними макетами, зручно використовувати
|
| Порада: | Комбінуйте |
Синтаксис
element.style.flexBasis
Значення
Return
Переглядачі
| Переглядач | |||||
|---|---|---|---|---|---|
1 |
1 |
3 |
8 |
12 |
| Переглядач | ||||
|---|---|---|---|---|
4.4 |
18 |
4 |
1 |
| Переглядач | ||
|---|---|---|
- |
- |
Приклади
У цьому прикладі користувач може вводити різні значення для властивості flexBasis (наприклад, 200px, 50%) у текстове поле та натискати кнопку "Застосувати". Це змінить початковий розмір гнучкого елемента, демонструючи, як працює властивість flexBasis.
Цей приклад демонструє, як можна застосувати різні значення flexBasis до елементів у контейнері flex на основі їхньої позиції. Кожен парний елемент займає 30% простору, а непарний - 70%. Це корисно для створення асиметричних макетів, де елементи повинні займати різні пропорції простору.
const container = document.getElementById('container');
const items = container.children;
for (let i = 0; i < items.length; i++) {
if (i % 2 === 0) {
items[i].style.flexBasis = '30%';
} else {
items[i].style.flexBasis = '70%';
}
}
Цей приклад показує, як динамічно змінювати значення flexBasis залежно від розміру контейнера. Якщо ширина контейнера перевищує 600 пікселів, елементи займають третину простору з відступом, в іншому випадку - половину простору. Це корисно для створення адаптивних макетів, які автоматично підлаштовуються під розміри вікна браузера.
const container = document.getElementById('dynamicContainer');
const items = container.children;
function updateFlexBasis() {
const containerWidth = container.clientWidth;
for (let item of items) {
item.style.flexBasis = containerWidth > 600 ? 'calc(33.33% - 20px)' : 'calc(50% - 10px)';
}
}
window.addEventListener('resize', updateFlexBasis);
updateFlexBasis();
