position

Властивість CSS position (положення) вказує на те, як елемент розміщується в документі. Властивості top, right, bottom та left визначають остаточне місцеположення розміщених елементів.

Спробуйте його в дії

Синтаксис

position: static;
position: relative;
position: absolute;
position: fixed;
position: sticky;

/* Глобальні значення */
position: inherit;
position: initial;
position: revert;
position: revert-layer;
position: unset;

Значення

static (статичне)

Елемент позиціонується згідно зі Звичайним плином документа. Властивості top, right, bottom, left та z-index не діють. Таке значення є усталеним.

relative (відносне)

Елемент позиціонується згідно зі звичайним плином документа, а тоді відступає вбік відносно початкового положення на основі значень top, right, bottom та left. Відступ жодним чином не впливає на розміщення інших елементів; таким чином, простір, виділений для елемента у макеті сторінки, залишається таким самим, як був би, якби його position мала значення static.

Це значення створює новий контекст нагромадження, коли значення z-index відмінне від auto. Його вплив на елементи table-*-group, table-row, table-column, table-cell та table-caption є невизначеним.

absolute (абсолютне)

Елемент зникає зі звичайного плину документа, і для нього не виділяється жодного простору у макеті сторінки. Такий елемент позиціонується відносно до свого найближчого позиціонованого предка (якщо такий є) або початкового контейнерного блока. Його остаточна позиція визначена значеннями властивостей top, right, bottom та left.

Це значення створює новий контекст нагромадження, коли значення z-index відмінне від auto. Зовнішні поля абсолютно позиціонованих елементів не перекриваються з іншими зовнішніми полями.

fixed (фіксоване)

Елемент зникає зі звичайного плину документа, і для нього не виділяється жодного простору у макеті сторінки. Такий елемент позиціонується відносно свого початкового контейнерного блока, котрим у випадку візуального представлення є область перегляду. Остаточна позиція елемента визначена значеннями властивостей top, right, bottom та left.

Це значення завжди створює новий контекст нагромадження. При друкові документа такий елемент друкується на одній позиції на кожній сторінці.

sticky (липкий)

Елемент позиціонується згідно зі звичайним плином документа, а далі зміщується відносно до свого найближчого предка з прокручуванням та контейнерного блока (найближчого предка блокового рівня), включно з елементами таблиць, на основі значень властивостей top, right, bottom та left. Відступ не впливає на позицію інших елементів.

Це значення завжди створює новий контекст нагромадження. Зверніть увагу, що липкий елемент "прилипає" до свого найближчого предка, який має "механізм прокручування" (утворений встановленням властивості overflow у значення hidden, scroll, auto чи overlay), навіть коли такий предок не є найближчим справді прокручуваним предком.

[!NOTE] Щонайменше одна зі властивостей inset (top, inset-block-start, right, inset-inline-end тощо) повинна мати значення, відмінне від auto, за віссю, за якою елемент повинен стати липким. Якщо обидві властивості inset за віссю мають значення auto, то за цією віссю значення sticky буде поводитися як relative.

Опис

Типи позиціонування

  • Позиціонований елемент – елемент, в котрого обчислене значення position – одне з наступних: relative, absolute, fixed, sticky. (Інакше кажучи, що завгодно, окрім static.)
  • Відносно позиціонований елемент – елемент, в котрого обчислене значення positionrelative. Властивості top та bottom вказують вертикальний відступ від його звичайної позиції; властивості left та right вказують горизонтальний відступ.
  • Абсолютно позиціонований елемент – елемент, в котрого обчислене значення positionabsolute або fixed. Властивості top, right, bottom та left вказують відступи від країв контейнерного блока елемента. (Контейнерний блок – то предок, відносно якого позиціонується елемент.) Якщо елемент має зовнішні поля, то вони додаються до відступів. Елемент утворює новий контекст блокового форматування (КБФ) для свого вмісту.
  • Липко позиціонований елемент – елемент, в котрого обчислене значення positionsticky. Він розглядається як відносно позиціонований, поки його контейнерний блок не перетне встановлений поріг (встановлений, наприклад, значенням властивості top, відмінним від auto) всередині свого кореня плину (чи контейнера, всередині якого він прокручується), після чого буде вважатись "застряглим", поки не зустріне протилежний край свого контейнерного блоку.

Переважну більшість часу абсолютно позиціоновані елементи, що мають height та width зі значенням auto, мають розмір, відповідний їх вмістові. Втім, не заміщені, абсолютно позиціоновані елементи можуть бути змушені заповнювати увесь доступний простір по вертикалі шляхом вказання top та bottom і залишення height невказаною (тобто auto). Вони можуть аналогічно бути змушені заповнювати ввесь доступний простір по горизонталі шляхом встановлення left та right і залишення widthauto.

Окрім вищеописаного випадку (абсолютно позиціонованих елементів, що заповнюють доступний простір):

  • Якщо як top, так bottom – вказані (або, точніше кажучи, їх значення відмінне від auto), top перемагає.
  • Якщо як left, так right – вказані, то left перемагає, коли directionltr (англійська, горизонтальна японська тощо), а right перемагає, коли directionrtl (перська, арабська, іврит тощо).

Доступність

Пересвідчіться, що елементи, позиціоновані як absolute чи fixed, не затуляють решту змісту, коли збільшується зображення сторінки чи розмір тексту.

Швидкодія та доступність

Прокручування елементів, що мають вміст, позиційований як fixed чи sticky, може призводити до проблем зі швидкодією та доступністю. Поки користувач прокручує, браузер мусить перемальовувати липкий чи фіксований вміст у новому місці. Залежно від вмісту, що треба перемальовувати, швидкодії браузера та швидкості роботи пристрою браузер може не мати змоги підтримувати рівень перемальовування 60 кадрів на секунду. Такий сценарій може призвести до провисань і, що важливіше, до занепокоєння відносно людей з особливими потребами. Одне з рішень – додати will-change: transform до позиціонованих елементів, аби відмальовувати елемент у власному шарі, підвищивши швидкість перемальовування та, таким чином, покращити швидкодію та доступність.

Формальне визначення

Формальний синтаксис

static | relative | absolute | sticky | fixed

Приклади

Відносне позиціонування

Відносно позиціоновані елементи мають заданий відступ від звичайної позиції в документі, але, втім, їх відступ не впливає на інші елементи. У прикладі нижче зверніть увагу: інші елементи розміщені так, неначе блок "Два" займає місце у своєму звичайному положенні.

HTML

<div class="box" id="one">Один</div>
<div class="box" id="two">Два</div>
<div class="box" id="three">Три</div>
<div class="box" id="four">Чотири</div>

CSS

* {
  box-sizing: border-box;
}

.box {
  display: inline-block;
  width: 100px;
  height: 100px;
  background: red;
  color: white;
}

#two {
  position: relative;
  top: 20px;
  left: 20px;
  background: blue;
}

Абсолютне позиціонування

Елементи, що є відносно позиціонованими, залишаються у звичайному плині документа. На відміну від них, абсолютно позиціонований елемент виймається із плину; таким чином, інші елементи розміщуються так, ніби його не існує. Абсолютно позиціонований елемент позиціонується відносно до свого найближчого позиціонованого предка (наприклад, найближчого предка, що не є static). Якщо позиціонований предок не існує, елемент позиціонується відносно ПКБ (початкового контейнерного блока – дивіться також визначення W3C), котрий є контейнерним блоком кореневого елемента документа.

HTML

<h1>Абсолютне позиціонування</h1>

<p>
  Я є базовим елементом блокового рівня. Сусідні до мене елементи блокового
  рівня сидять на нових рядках нижче від мене.
</p>

<p class="positioned">
  Усталено ми займаємо 100% ширини свого батьківського елемента, і є настільки
  високими, наскільки високим є наш дочірній вміст. Наші підсумкові ширина та
  висота – це сума наших вмісту, внутрішніх відступів та ширини чи висоти меж.
</p>

<p>
  Ми розділені своїми зовнішніми полями. Завдяки перекриттю зовнішніх полів ми
  розділені шириною одного зовнішнього поля, а не двох.
</p>

<p>
  рядкові елементи, <span>як-от цей</span> та <span>цей</span>, сидять на одному
  й тому ж рядку, вкупі із суміжними текстовими вузлами, якщо на тому самому
  рядку є місце. Рядкові елементи з переповненням
  <span>завертають на новий рядок, якщо це можливо, як-от цей, із текстом</span
  >, або просто переходять на новий рядок, якщо це неможливо, як-ось це
  зображення: <img src="long.jpg" />
</p>

CSS

* {
  box-sizing: border-box;
}

body {
  width: 500px;
  margin: 0 auto;
}

p {
  background: aqua;
  border: 3px solid blue;
  padding: 10px;
  margin: 10px;
}

span {
  background: red;
  border: 1px solid black;
}

.positioned {
  position: absolute;
  background: yellow;
  top: 30px;
  left: 30px;
}

Результат

Фіксоване позиціонування

Фіксоване позиціонування є подібним до абсолютного позиціонування, за виключенням того, що контейнерний блок елемента є початковим контейнерним блоком, встановленим областю перегляду, якщо жоден предок не має властивості transform, perspective чи filter зі значенням, відмінним від none (дивіться Специфікацію CSS перетворень), що змусило б такого предка замінити елементові його контейнерний блок. Це може бути використано для створення "плавучого" елемента, котрий залишається на одній позиції незалежно від прокручування. У прикладі нижче елемент "Один" зафіксований на відстані 80 пікселів від верху сторінки і 10 пікселів від лівого краю. Навіть після прокручування він залишається на тому самому місці відносно області перегляду. Крім того, коли властивість will-change має значення transform, то встановлюється новий контейнерний блок.

HTML

<div class="outer">
  <p>
    Але щоб ви зрозуміли, звідки виникає це хибне уявлення людей, цуратись
    насолоди і вихваляти страждання, я розкрию перед вами всю картину і
    роз’ясню, що саме говорив цей чоловік, який відкрив істину, якого я б назвав
    зодчим щасливого життя. Дійсно, ніхто не відкидає, не зневажає, не уникає
    насолод тільки через те, що це насолоди, але лише через те, що тих, хто не
    вміє розумно вдаватися насолоді, осягають великі страждання. Так само як
    немає нікого, хто полюбивши, вважав за краще і зажадав би саме страждання
    тільки за те, що це страждання, а не тому, що інший раз виникають такі
    обставини, коли страждання і біль приносять якесь і чималу насолоду. Якщо
    скористатися найпростішим прикладом, то хто з нас став би займатися якими б
    то не було тяжкими фізичними вправами, якщо б це не приносило з собою якоїсь
    користі? І хто міг би по справедливості дорікнути прагнення до насолоди, яке
    не несло б з собою ніяких неприємностей, або того, хто уникав би такого
    страждання, яке не приносило б з собою ніякої насолоди?
  </p>
  <p>
    Але ми цураємось і вважаємо, що заслуговують справедливого обурення ті, хто,
    піддався звабі і розбещеним спокусам, які дають їм насолоду, і без тями від
    пристрасті не передбачили, яких страждань і які нещастя на них чекають. Вони
    винні так само, як і ті, хто через душевну слабкість, тобто через бажання
    уникнути страждань і болю відмовляється від виконання свого обов’язку. Втім,
    тут дуже легко і просто провести відмінності, тому що, коли ми вільні і нам
    надана повна можливість вибору бажаного, коли ніщо не заважає нам робити те,
    що нам більше подобається, будь яку насолоду слід визнати бажаним, а
    будь-яке страждання огидним. Але при деяких обставинах – або на вимогу
    боргу, або в силу якоїсь необхідності часто доводиться забувати про насолоди
    і не втікати від тягарів. Тому мудрець дотримується в цьому випадку
    наступного принципу вибору – або, відмовляючись від задоволення, він отримує
    якісь інші і навіть великі насолоди, або, зазнаючи страждання, він
    позбавляється від більш жорстоких.
  </p>
  <div class="box" id="one">Один</div>
</div>

CSS

* {
  box-sizing: border-box;
}

.box {
  width: 100px;
  height: 100px;
  background: red;
  color: white;
}

#one {
  position: fixed;
  top: 80px;
  left: 10px;
  background: blue;
}

.outer {
  width: 500px;
  height: 300px;
  overflow: scroll;
  padding-left: 150px;
}

Результат

Липке позиціонування

Наступне правило CSS позиціює елемент з ідентифікатором one відносно, поки область перегляду не прокрутиться так, що елемент перебуватиме за 10 пікселів від верху. Після проходження цього порогу елемент фіксується за 10 пікселів від верху.

#one {
  position: sticky;
  top: 10px;
}

Список з липкими заголовками

Загальноприйняте використання липкого позиціонування – заголовки списку, відсортованого за алфавітом. Заголовок "Б" з'явиться зразу після пунктів, що починаються з "А", поки вони прокручуються поза екраном. Замість вислизання за межі екрана разом з рештою вмісту, заголовок "Б" залишиться зафіксованим згори області перегляду, поки всі пункти "Б" не будуть прокручені поза екран, після чого буде перекритим заголовком "В", і так далі.

Обов'язково слід вказувати поріг в одній з властивостей: top, right, bottom чи left, щоб липке позиціонування поводилось як очікується.

HTML
<dl>
  <div>
    <dt>А</dt>
    <dd>Абу-Касимові Капці</dd>
    <dd>Аква-Віта</dd>
    <dd>Андерсон</dd>
    <dd>Астарта</dd>
    <dd>АтмАсфера</dd>
  </div>
  <div>
    <dt>В</dt>
    <dd>Вагоновожатые</dd>
    <dd>Вежа хмар</dd>
    <dd>Вій</dd>
    <dd>Воплі Відоплясова</dd>
    <dd>Вхід у змінному взутті</dd>
  </div>
  <div>
    <dt>Ґ</dt>
    <dd>Ґринджоли</dd>
  </div>
  <div>
    <dt>П</dt>
    <dd>Перкалаба</dd>
    <dd>Пирятин</dd>
    <dd>Піккардійська терція</dd>
    <dd>Пісні наших днів</dd>
    <dd>Плач Єремії</dd>
  </div>
</dl>
CSS
* {
  box-sizing: border-box;
}

dl > div {
  background: #fff;
  padding: 24px 0 0 0;
}

dt {
  background: #b8c1c8;
  border-bottom: 1px solid #989ea4;
  border-top: 1px solid #717d85;
  color: #fff;
  font:
    bold 18px/21px Helvetica,
    Arial,
    sans-serif;
  margin: 0;
  padding: 2px 0 0 12px;
  position: -webkit-sticky;
  position: sticky;
  top: -1px;
}

dd {
  font:
    bold 20px/45px Helvetica,
    Arial,
    sans-serif;
  margin: 0;
  padding: 0 0 0 12px;
  white-space: nowrap;
}

dd + dd {
  border-top: 1px solid #ccc;
}
Результат

Липке позиціювання з заданням усіх чотирьох відступів

Наступний приклад демонструє поведінку елемента, коли задано всі чотири відступи. Тут в абзаці є два емоджі лампочок. Лампочки використовують липке позиціювання, і їх відступи задані як 50px від верху, 100px від правого боку, 50px від низу та 50px від лівого боку. Сіре тло батьківського елемента div позначає область, у якій відбувається відступання.

HTML
Скористайтеся смугами прокручення, щоб помістити лампочки (💡) в правильне місце
в наступному тексті:
<div>
  <p>
    Подання ідеї у вигляді лампочки (<span class="bulb">💡</span>) – поширена
    метафора, що символізує момент натхнення чи народження нової ідеї. Асоціацію
    між лампочкою та ідеєю можна відстежити до винаходу Томасом Едісоном у кінці
    XIX сторіччя лампи розжарювання (<span class="bulb">💡</span>). Лампочка –
    потужний символ, тому що представляє освітлення, ясність і раптовий спалах
    чиїхось думок або розуміння. Коли хтось має ідею, вона нерідко описується як
    лампочка, що ввімкнулася в голові, позначивши мить прозріння чи творчості.
    Зображення лампочки також вказує на ідею з енергією, силою та потенціалом
    для росту та розвитку.
  </p>
</div>
CSS
.bulb {
  position: sticky;
  inset: 50px 100px 50px 100px;
}

div {
  /* область, визначена відступами, позначена сірим кольором */
  background: linear-gradient(#9999, #9999) 100px 50px / 192px 100px no-repeat;
}
Результат

Коли поставите обидві лампочки в правильні місця, то помітите: щодо області відступів вони позиційовані відносно. Коли ви перемістите їх геть з області відступів, вони стають зафіксованими (липкими) щодо відступу за відповідним напрямком.

Специфікації

Сумісність із браузерами

desktop mobile
Chrome Edge Firefox Internet Explorer Opera Safari WebView Android Chrome Android Firefox for Android Opera Android Safari on iOS Samsung Internet
position
Chrome Full support 1
Edge Full support 12
Firefox Full support 1
footnote
Internet Explorer Full support 4
Opera Full support 4
Safari Full support 1
WebView Android Full support 37
Chrome Android Full support 18
Firefox for Android Full support 4
footnote
Opera Android Full support 14
Safari on iOS Full support 1
Samsung Internet Full support 1.0
Absolutely-positioned flex children
Chrome Full support 52
Edge Full support 12
Firefox Full support 52
Internet Explorer Full support 10
Opera Full support 39
Safari Full support 11
WebView Android Full support 52
Chrome Android Full support 52
Firefox for Android Full support 52
Opera Android Full support 41
Safari on iOS Full support 11
Samsung Internet Full support 6.0
fixed
Chrome Full support 1
Edge Full support 12
Firefox Full support 1
footnote
Internet Explorer Full support 7
footnote
Opera Full support 4
Safari Full support 1
WebView Android Full support 37
Chrome Android Full support 18
Firefox for Android Full support 4
footnote
Opera Android Full support 14
Safari on iOS Full support 1
Samsung Internet Full support 1.0
Table elements as sticky positioning containers
Chrome Full support 56
Edge Full support 16
Firefox Full support 59
Internet Explorer No support Ні
Opera Full support 43
Safari Full support 8
WebView Android Full support 56
Chrome Android Full support 56
Firefox for Android Full support 59
Opera Android Full support 43
Safari on iOS Full support 8
Samsung Internet Full support 6.0
sticky
Chrome Full support 56
Edge Full support 16
Firefox Full support 32
Internet Explorer No support Ні
Opera Full support 43
Safari Full support 13
WebView Android Full support 56
Chrome Android Full support 56
Firefox for Android Full support 32
Opera Android Full support 43
Safari on iOS Full support 13
Samsung Internet Full support 6.0

Дивіться також