Css3 позиционирование: Методы позиционирования элементов в CSS

Содержание

Позиционирование - Изучение веб-разработки | MDN

Позиционирование позволяет вам изымать элементы из нормального потока макета документа и заставить их вести себя по-другому; например, располагаться друг на друге или всегда оставаться на одном и том же месте внутри окна просмотра браузера. Эта статья объясняет разные значения position и как их использовать.

Необходимые знания:

Основы HTML (изучите Введение в HTML), идея о том как работает CSS (изучите Введение в CSS.)

Задача: Изучить как работает CSS позиционирование.

Нам бы хотелось чтобы вы следовали за нами с упражнениями на вашем локальном ПК, если возможно возьмите копию 0_basic-flow.html из нашего GitHub репозитория (исходный код здесь) и используйте его как отправную точку.

Вся идея позиционирования заключается в том, чтобы позволить нам переопределять поведение базового потока документа, описанного выше, для того чтобы производить интересные эффекты.

Что если вам захочется слегка изменить позицию каких-либо блоков внутри макета относительно их позиции в потоке макета по умолчанию? Ваш инструмент - позиционирование. Или если вы хотите создать элемент пользовательского интерфейса, который плавает над другими частями страницы и/или всегда располагается на одном и том же месте в окне браузера не зависимо от того сколько прокручивалась страница? Позиционирование делает возможным работу таких макетов.

Существует несколько разных типов позиционирования, которые вы можете применить к элементам HTML. Для активации специфического типа позиционирования у элемента, мы используем свойство position.

Статическое позиционирование

Статическое позиционирование — это умолчание, которое получает каждый элемент, что всего лишь значит "поставить элемент в его нормальное положение в потоке макета документа — ничего особенного для рассмотрения".

Чтобы продемонстрировать это и настроить ваш образец для будущих разделов, сначала добавьте class positioned ко второму <p> в HTML:

<p> .
.. </p>

А теперь добавьте следующее правило в конец вашего CSS:

.positioned {
  position: static;
  background: yellow;
}

И если вы сейчас сохраните и обновите, то вы не увидите никаких изменений, не считая обновленного цвета фона 2-го параграфа. Это нормально, как мы и говорили ранее, статическое позиционирование является поведением по умолчанию!

Относительное позиционирование

Относительное позиционирование первый тип позиции, который мы рассмотрим. Оно очень похоже на статическое позиционирование, за исключением того что вы можете модифицировать окончательное положение позиционируемого объекта занявшего свое место в макете нормального потока, в том числе заставлять его перекрывать другие элементы на странице. Двигайтесь далее и обновите объявление position в вашем коде:

position: relative;

Если вы сохраните и обновите на данном этапе, в результате вы совсем не увидите изменений. Так как же вам модифицировать положение? Вам необходимо использовать свойства

top, bottom, left, и right которые мы объясним в следующем разделе.

Введение в top, bottom, left, и right

top, bottom, left, и right используются вместе с position чтобы указать куда именно перемещать позиционируемый элемент. Для того чтобы попробовать, добавьте следующее объявление к правилу .positioned в вашем CSS:

top: 30px;
left: 30px;

Примечание: значения этих свойств могут принимать любые единицы которые вы ожидаете по логике: пиксели, мм, rems, %, и т.д.

Если вы сейчас сохраните и обновите, вы получите примерно такой результат:

Круто, правда? Хорошо, вероятно это не то, чего вы ожидали — почему он переместился вниз и вправо, когда мы указали вверх и влево? Как бы нелогично это ни звучало это всего лишь способ того как работает позиционирование — вам надо думать о невидимой силе толкающей указанную сторону позиционируемого блока, перемещая его в противоположную сторону.

Так, например, если вы указали top: 30px;, сила толкает блок, заставляя его перемещаться вниз на 30px.

Абсолютное позиционирование

Абсолютное позиционирование дает совершенно другие результаты. Давайте попробуем изменить объявление позиции в вашем коде как показано ниже:

position: absolute;

Если вы сохраните и обновновите, то вы должны увидеть нечто подобное:

В первую очередь обратите внимание на то, что интервал там, где должен быть позиционируемый элемент в потоке документа теперь отсутствует — первый и третий элементы сблизились так будто, он больше не существует! Ну, в каком-то смысле это правда. Абсолютно позиционированный элемент больше не существует в нормальном потоке макета документа. Вместо этого он располагается на своем собственном слое отдельно от всего остального. Это очень полезно: это значит, что мы можем создавать изолированные функции пользовательского интерфейса, которые не влияют на макет других элементов страницы. Например, всплывающие информационные блоки и меню управления; опрокидывающиеся панели; функции пользовательского интерфейса, которые можно перетаскивать в любом месте страницы; и так далее...

Во-вторых, обратите внимание, что позиция элемента изменилась — это потому, что top, bottom, left, и right ведут себя по-другому с абсолютным позиционированием. Вместо того, чтобы позиционировать элемент на основе его относительного положения в обычном потоке макета документа, они определяют расстояние, на котором элемент должен находиться от каждой из сторон содержащего элемента. Поэтому в этом случае мы говорим, что абсолютно позиционированный элемент должен располагаться в 30px от верха "содержащего элемента" и 30px от левого края (В этом случае "содержащий элемент" является исходным содержащим блоком. См. раздел ниже для дополнительной информации).

Примечание: Вы можете использовать top, bottom, left, и right для изменения размера элемента если вам надо.

Попробуйте установить top: 0; bottom: 0; left: 0; right: 0; и margin: 0; для вашего позиционируемого элемента и посмотрите, что произойдет! Потом снова все верните...

Примечание: Да, margin-ы все еще влияют на позиционируемый элемент. Однако, схлопывания margin не происходит.

Контекст позиционирования

Какой элемент является "содержащим" относительно абсолютно позиционируемого элемента? Это очень сильно зависит от свойства позиции предка позиционируемого элемента (см. Определение содержащего блока).

Если никакие из элементов предков не имеют конкретно заданного свойства позиции, то по умолчанию все элементы предков будут иметь статическую позицию. В результате этого абсолютно позиционируемый элемент будет содержаться в исходным содержащем блоке. Исходный содержащий блок имеет размеры области просмотра, а также является блоком, содержащим элемент <html>. Проще говоря, абсолютно позиционируемый элемент будет отображаться за пределами элемента <html> и будет расположен относительно исходного окна просмотра.

Позиционируемый элемент вложен в <body> в исходном HTML, но в конечном макете он расположен на 30px от верхнего и левого края страницы. Мы можем изменить контекст позиционирования — относительно какого элемента позиционируется позиционируемый элемент. Это делается путем установки позиционирования на одном из предков элемента — на один из элементов, внутри которого он вложен (вы не можете позиционировать его относительно элемента, внутри которого он НЕ вложен). Чтобы продемонстрировать это, добавьте следующее объявление в правило вашего body:

position: relative;

Это должно дать следующий результат:

Позиционируемый элемент теперь располагается относительно элемента <body>.

Введение в z-index

Все это абсолютное позиционирование — хорошее развлечение, но кое-что чего мы еще не рассмотрели — когда элементы начинают перекрываться, что определяет который из элементов будет появляться поверх другого элемента? В примере, который мы видели все это время, у нас имеется только один позиционируемый элемент в контексте позиционирования, и он появляется сверху поскольку позиционируемые элементы "побеждают" не позиционированные элементы.

Что же насчет того, когда мы имеем более одного?

Попробуйте добавить следующий CSS, чтобы сделать первый параграф так же абсолютно позиционированным:

p:nth-of-type(1) {
  position: absolute;
  background: lime;
  top: 10px;
  right: 30px;
}

На этом этапе вы увидите, что первый параграф окрашенный в лаймовый изъят из потока документа и помещен чуточку выше того места, где он был исходно. А также он расположен под оригинальным параграфом .positioned, где они оба перекрываются. Это потому что параграф .positioned является вторым параграфом по порядку в источнике и позже позиционируемые элементы в порядке источника выигрывают над ранее позиционируемыми элементами в порядке источника.

Можете ли вы изменить порядок наложения? Да, можете, используя свойство z-index. "z-index" это ссылка к z-оси. Вы можете вспомнить из предыдущих этапов в этом курсе, где мы обсуждали использование горизонтальных (x-ось) и вертикальных (y-оси) координат веб-страницами для определения позиции для таких вещей, как фоновые изображения и смещение теней.

(0,0) находится наверху слева страницы (или элемента) и оси x- и y- направляются направо и вниз страницы (во всяком случае, для языков, направленных слева на право).

У веб-страниц также имеется z-ось: воображаемая линия, которая направляется от поверхности вашего экрана к вашему лицу (или что еще вам нравится иметь перед экраном). Значения z-index влияют на то где позиционируемый элемент располагается на этой оси; положительные значения перемещают их выше по наложению, а отрицательные значения перемещают их ниже по наложению. По умолчанию все позиционируемые элементы имеют z-index auto, что фактически равно 0.

Для того чтобы изменить порядок наложения, попробуйте объявить для вашего p:nth-of-type(1) правила:

z-index: 1;

Теперь вы должны видеть законченный пример, с параграфом лаймового цвета сверху:

Обратите внимание что z-index принимает значения индекса только без единиц измерения; вы не можете задавать значения, что хотите, чтобы какой-то элемент был на 23 пикселя выше по z-оси — это так не работает. Более высокие значения будут располагаться над меньшими значениями и от вас зависит какие значения вы используете. Используя 2 и 3, вы получите тот же эффект что и 300 и 40000.

Фиксированное позиционированиее

А теперь давайте посмотрим на фиксированное позиционирование. Оно работает точно также как и абсолютное позиционирование, одним ключевым отличием: в то время как абсолютное позиционирование фиксирует элемент в месте относительно его ближайшего позиционированного предка (исходный содержащий блок если нет иного), фиксированное позиционирование обычно фиксирует элемент в месте относительно видимой части области просмотра, кроме случаев, когда один из его потомков является фиксированным блоком из-за того, что его свойству transform отличается от none. Это значит, что вы можете создать элементы пользовательского интерфейса, которые зафиксированы на месте, как постоянные меню навигации, которые всегда видимы вне зависимости от того сколько прокручивается страница.

Давайте составим простой пример, чтобы показать, что мы имеем в виду. Во-первых, удалите существующие правила p:nth-of-type(1) и .positioned из вашего CSS.

А теперь, обновите правило body удалив объявление position: relative; и добавьте фиксированную высоту как тут:

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

Теперь мы собираемся дать элементу <h2> position: fixed;, а также заставить его располагаться на верху окна просмотра. Добавьте следующее правило в ваш CSS:

h2 {
  position: fixed;
  top: 0;
  width: 500px;
  margin-top: 0;
  background: white;
  padding: 10px;
}

top: 0; необходим чтобы приклеить его к верху экрана. мы дали заголовку ту же ширину что и колонкам с контентом и затем даем ему белый фон и немного padding и margin, чтобы контент не был видимым под ним.

Если вы сохраните и обновите сейчас, вы увидите маленький забавный эффект, при котором заголовок останется неизменным, а содержимое будет прокручиваться вверх и исчезать под ним. Но мы можем улучшить это — в данный момент некоторый контент начинается под заголовком. Это из-за того, что позиционируемый заголовок больше не появляется в потоке документа, поэтому остальное содержимое поднимается наверх. Нам надо сдвинуть все это немного вниз; мы можем сделать это установив немного верхнего margin к первому параграфу. Добавьте его сейчас:

p:nth-of-type(1) {
  margin-top: 60px;
}

Теверь вы должны видеть законченный пример:

position: sticky

Доступно другое значение позиции называемое position: sticky, которое несколько новее чем другие. По сути, это гибрид относительной и фиксированной позиции, который позволяет позиционируемому элементу вести себя как будто он относительно позиционирован, до тех пор пока он не будет прокручен до определенной пороговой точки (напрмер, 10px от вершины окна просмотра), после чего он становится фиксированным.  Это можно использовать, например, чтобы заставить панель навигации прокручиваться вместе со страницей до определенной точки, а затем задерживать в верхней части страницы.

.positioned {
  position: sticky;
  top: 30px;
  left: 30px;
}

Интересное и общее использование position: sticky заключается в создании индексных страниц с прокруткой, где разные заголовки липнут к верху страницы, когда они достигают его. Разметка такого примера может выглядеть так:

<h2>Sticky positioning</h2>

<dl>
    <dt>A</dt>
    <dd>Apple</dd>
    <dd>Ant</dd>
    <dd>Altimeter</dd>
    <dd>Airplane</dd>
    <dt>B</dt>
    <dd>Bird</dd>
    <dd>Buzzard</dd>
    <dd>Bee</dd>
    <dd>Banana</dd>
    <dd>Beanstalk</dd>
    <dt>C</dt>
    <dd>Calculator</dd>
    <dd>Cane</dd>
    <dd>Camera</dd>
    <dd>Camel</dd>
    <dt>D</dt>
    <dd>Duck</dd>
    <dd>Dime</dd>
    <dd>Dipstick</dd>
    <dd>Drone</dd>
    <dt>E</dt>
    <dd>Egg</dd>
    <dd>Elephant</dd>
    <dd>Egret</dd>
</dl>

CSS может выглядеть как показано ниже. В нормальном потоке элементы <dt> будут прокручиваться вместе с контентом. Когда мы добавляем position: sticky к элементу <dt>, вместе со значением top 0, поддерживающие браузеры будут приклеивать заголовки к вершине окна просмотра когда они будут достигать той позиции. каждый последующий заголовок будет затем заменять предыдущий при его прокрутке вверх к той позиции.

dt {
  background-color: black;
  color: white;
  padding: 10px;
  position: sticky;
  top: 0;
  left: 0;
  margin: 1em 0;
}

Липкие элементы являются "липкими" относительно ближайшего предка с "прокручивающимся механизмом", который определяется свойством позиции его предка.

Вы достигли конца этой статьи, но помните ли вы самую важную информацию? Вы можете найти дальнейшую проверку что вы усвоили эту информацию прежде чем, отправитесь дальше — см. Проверьте свои навыки: Позиционирование.

Я уверен, что вы повеселились с основами позиционирования; хотя это не является методом, который вы бы использовали для целого макета, все же как вы видите, существует много задач, подходящих для него.

CSS - Позиционирование - CoderLessons.com

CSS поможет вам позиционировать ваш HTML-элемент. Вы можете поместить любой HTML-элемент в любое удобное вам место. Вы можете указать, хотите ли вы, чтобы элемент располагался относительно его естественного положения на странице или абсолютного на основе его родительского элемента.

Теперь мы увидим все связанные с CSS свойства позиционирования на примерах —

Относительное позиционирование

Относительное позиционирование изменяет положение элемента HTML относительно того места, где оно обычно появляется. Таким образом, «left: 20» добавляет 20 пикселей в левую позицию элемента.

Вы можете использовать два значения top и left вместе со свойством position, чтобы переместить элемент HTML в любое место HTML-документа.

  • Переместить влево — использовать отрицательное значение для левого .
  • Переместить вправо — использовать положительное значение для левого .
  • Move Up — Используйте отрицательное значение для верхней части .
  • Переместить вниз — используйте положительное значение для верхней части .

ПРИМЕЧАНИЕ. — Можно использовать нижнее или правое значения так же, как верхнее и левое .

Вот пример —

Live Demo

<html>
   <head>
   </head>

   <body>
      <div style = " position:relative; left:80px; top:2px; background-color:yellow;">
         This div has relative positioning.
      </div>
   </body>
</html>

Это даст следующий результат —

Абсолютное позиционирование

Элемент с position: absolute располагается в указанных координатах относительно левого верхнего угла экрана.

Вы можете использовать два значения top и left вместе со свойством position, чтобы переместить элемент HTML в любое место HTML-документа.

  • Переместить влево — использовать отрицательное значение для левого .
  • Переместить вправо — использовать положительное значение для левого .
  • Move Up — Используйте отрицательное значение для верхней части .
  • Переместить вниз — используйте положительное значение для верхней части .

ПРИМЕЧАНИЕ. — Можно использовать нижнее или правое значения так же, как верхнее и левое.

Вот пример —

Live Demo

<html>
   <head>
   </head>

   <body>
      <div style = " position:absolute; left:80px; top:20px;  background-color:yellow;">
         This div has absolute positioning.
      </div>
   </body>
</html> 

Фиксированное позиционирование

Фиксированное позиционирование позволяет фиксировать положение элемента в определенном месте на странице независимо от прокрутки. Указанные координаты будут относительно окна браузера.

Вы можете использовать два значения top и left вместе со свойством position, чтобы переместить элемент HTML в любое место HTML-документа.

  • Переместить влево — использовать отрицательное значение для левого .
  • Переместить вправо — использовать положительное значение для левого .
  • Move Up — Используйте отрицательное значение для верхней части .
  • Переместить вниз — используйте положительное значение для верхней части .

ПРИМЕЧАНИЕ. — Можно использовать нижнее или правое значения так же, как верхнее и левое .

Вот пример —

Как работает позиционирование в CSS?

  • Главная
  • ->
  • Материалы
  • ->
  • Как работает позиционирование в CSS?

Reg. ru: домены и хостинг

Крупнейший регистратор и хостинг-провайдер в России.

Более 2 миллионов доменных имен на обслуживании.

Продвижение, почта для домена, решения для бизнеса.

Более 700 тыс. клиентов по всему миру уже сделали свой выбор.

Перейти на сайт->

Бесплатный Курс "Практика HTML5 и CSS3"

Освойте бесплатно пошаговый видеокурс

по основам адаптивной верстки

на HTML5 и CSS3 с полного нуля.

Начать->

Фреймворк Bootstrap: быстрая адаптивная вёрстка

Пошаговый видеокурс по основам адаптивной верстки в фреймворке Bootstrap.

Научитесь верстать просто, быстро и качественно, используя мощный и практичный инструмент.

Верстайте на заказ и получайте деньги.

Получить в подарок->

Бесплатный курс "Сайт на WordPress"

Хотите освоить CMS WordPress?

Получите уроки по дизайну и верстке сайта на WordPress.

Научитесь работать с темами и нарезать макет.

Бесплатный видеокурс по рисованию дизайна сайта, его верстке и установке на CMS WordPress!

Получить в подарок->

*Наведите курсор мыши для приостановки прокрутки.

Назад Вперед


Как работает позиционирование в CSS?

Исходники

Пример

Несомненно, свойство position - один из наиболее мощных инструментов, которым обладают веб-разработчики и дизайнеры. Однако есть в этом свойстве некоторые моменты, которые могут поставить новичков в тупик.

Итак, что же такое позиционирование?

Когда Ваш браузер открывает страницу, он начинает так называемую отрисовку (рендеринг) элементов веб-страницы (блоки div, параграфы, заголовки и т.п.) в том порядке, в котором они появляются в разметке HTML-страницы.

Позиционирование предназначено для того, чтобы упорядочить процесс отображения элементов на странице. Существует 4 типа позиционирования и свойство inherit, предназначенное для обозначения того, что элемент должен наследовать значение родительского элемента:

1. static
2. relative
3. absolute
4. fixed
5. inherit

По умолчанию элементы имеют позиционирование static

По умолчанию ко всем элементам страницы браузер применяет позиционирование static. Такое позиционирование означает, что каждый элемент располагается соответственно естественному порядку - порядку добавления его на страницу.

Блочные элементы располагаются под блочными элементами, строчные элементы располагаются непосредственно друг за другом.

В чем основное отличие между блочными и строчными элементами?

Строчные элементы (inline) по определению не имеют верхнего и нижнего отступа. В общем потоке страницы строчные элементы идут друг за другом, то есть в одной строке. На другую же строку они переходят только тогда, когда доходят до конца строки, либо когда что-то принудительно заставляет их перейти на новую строку.

Блочные элементы (block), в отличие от строчных, в общем потоке страницы располагаются один под другим, по одному в каждой строке.

Относительное позиционирование

Установка свойства position в значение relative сама по себе не производит визуальных изменений на странице. Однако с этих пор мы имеем возможность изменить положение элемента относительно его нормальной позиции, используя свойства top, right, bottom и left.

Данный подход удобно использовать, если нужно сместить элемент, но при этом не привязывать его к жестко заданной позиции на странице.


.relativeDiv{

/*сдвигаем блок вверх-влево относительно его нормальной позиции:*/

position:relative;
top:-50px;
left:-100px;
}


Фиксированное позиционирование

При использовании position: fixed расположение элемента рассчитывается относительно окна браузера. Это позволяет, например, отображать какие-нибудь панели, навигационные меню и т.п. всегда в одном и том же месте экрана, в не зависимости от использования прокрутки в браузере. Для позиционирования элемента в этом случае точно также используются свойства top, right, bottom и left.


.fixedDiv{

/*Фиксируем блок div в 20 пикселях от нижней части окна браузера*/

position:fixed;
right:20px;
bottom:20px;
}


Абсолютное позиционирование

Если элемент абсолютно позиционирован, то другие элементы при этом отображаются на веб-странице так, как будто абсолютно позиционированного элемента и нет.

Положение элемента задается уже описанными выше свойствами left, top, right и bottom. Кроме того, на его положение влияет значение свойства position родительского элемента.

Так, если у родителя значение position установлено как static, либо родителя нет, то отсчет координат ведется от края окна браузера.

Если у родителя значение position задано как fixed, relative или absolute, то отсчет координат ведется от края родительского элемента.


.parentDiv{

/* аналогичный эффект будет также при
position: fixed; и position: absolute;*/

position:relative;
}
.absoluteDiv{

/*Позиционируем absoluteDiv относительно родительского parentDiv*/

position:absolute;
right:50px;
top:90px;
}


Используя свойства позиционирования, можно создать любые шаблоны страниц. В сочетании со свойством z-index Вы можете обойти обычное поведение при отображении элементов (по умолчанию элементы, идущие в коде позже, отображаются поверх элементов, шедших ранее).

По материалам tutorialzine.com
Перевод - Дмитрий Науменко

P.S. Хотите разобраться с CSS и научиться верстать? Посмотрите еще серию бесплатных видео по резиновой верстке сайта и бесплатный курс по основам адаптивной верстки. Эти материалы помогут вам продвинуться вперед гораздо быстрее:

Понравился материал и хотите отблагодарить?
Просто поделитесь с друзьями и коллегами!


Смотрите также:

Наверх

Как работает автоматическое позиционирование в CSS?

Несколько недель назад Андрей задал интересный вопрос в комментариях к одной из моих публикаций посвященных созданию навигации для сайтов. Андрей отметил что подменю имеет абсолютное позиционирование в то время как ни для одного из его родительских элементов позиционирование задано не было. Почему тогда подменю отображается точно под родительской ссылкой?

Если честно, я не знал что ответить. Как и Андрею, мне казалось что при отсутствии других элементов с заданным позиционированием, подменю должно было позиционироваться относительно элемента html и отображаться в верхнем левом углу браузера, но на практике все обстояло иначе.

Объяснение оказалось очень простым, хотя чтобы его найти пришлось провести маленькое расследование. Не буду описывать как именно я нашел объяснение, просто поделюсь результатом.

Содержащие блоки задают контекст позиционирования

Если вкратце, когда мы задаем элементу позиционирование, оно рассчитывается относительно содержащего блока. Таким содержащим блоком является ближайший родительский элемент с позиционированием отличным от static. Если для родительских элементов не указано позиционирование, содержащим блоком становится начальный блок - элемент html.

В своей публикации я описал как можно создать выпадающее меню с помощью шаблона Suckerfish. Я использую Suckerfish уже давно, так же как наверное и вы. По умолчанию подменю располагается далеко за пределами страницы, обычно на -999em слева от нее. При наведении курсора значение для left изменяется на auto и подменю появляется прямо под родительским пунктом меню.

На первый взгляд, подменю не подвергается действию вышеизложенного принципа позиционирования относительно содержащих блоков. Ни для одного из его родительских элементов позиционирование не задано, значит подменю должно позиционироваться относительно элемента html или же окна браузера.

По крайней мере, так думали я и Андрей. Наша ошибка состояла в понимании принципа работы значения auto.

Как браузеры интерпретируют значение auto?

Мы оба предполагали, что значение auto эквивалентно 0, тоесть запись left:auto равняется left:0. В некоторых случаях значение auto в СSS действительно равняется нулю, но не в этом.

Когда для элемента указано position: absolute, его расположение (и часто размер) регулируются свойствами top, right, bottom и left. Эти свойства указывают отклонение от исходного размещения элемента относительно содержащего блока. Для элементов, прописанных с помощью непарных тегов (<img>, <input>), результат при применении значения auto (для свойства top, right, bottom или left) зависит от того задано ли оно для остальных атрибутов позиционирования.

Последнее является ключевым моментом. По умолчанию auto не эквивалентно 0. Оно может быть равно 0, но это зависит от того какие значения заданы для остальных атрибутов позиционирования.

Выпадающее меню Suckerfish задает и впоследствии изменяет значение свойства left, остальные три свойства остаются auto. Когда мы изначально указываем left: -999em, в действие вступает свойство right и подменю располагается далеко за пределами страницы. При наведении курсора, когда значение свойства left меняется на auto, все четыре позиционирующие атрибуты получают значение auto.

Статья об элементах с абсолютным авто-позиционированием объясняет что именно происходит, так же как и эта статья с Dev.Opera об абсолютном и фиксированном позиционировании. Ниже приведена цитата из последней.

Значением по умолчанию для атрибутов top, right, bottom и left является auto, значит блок с абсолютным позиционированием расположен там где он был бы расположен без позиционирования. Однако, он удален из нормального потока и перекрывает любой элемент который следует за ним.

Вы можете увидеть примеры на изображениях ниже и выше в этой статье. На изображении выше меню появляется при наведении курсора на родительскую ссылку. В этом случае значением для свойства left (а также для top, right и bottom) является auto.

На изображении ниже такое же меню без позиционирования для подменю. Подменю расположено так же как и на изображении выше. Элементы меню верхнего уровня располагаются в разных частях изображений, так как во втором случае подменю присутствует в нормальном потоке документа, но само подменю расположено в одном и том же месте на обеих изображениях.

Если задуматься, все логично. Если бы по умолчанию auto было равно 0, элемент со значением 0 для всех сторон должен был бы растягиваться до границ своего контейнера. В некоторых случаях мы рассчитываем на то что он так и будет себя вести, например при вертикальном центрирование элементов.

В нашем случае происходит по другому. Когда для всех 4 сторон (или же для двух противоположных сторон) указано значение auto, расположение элемента зависит от интерпретации браузером.

Мы используем такое поведение для выравнивания центрального блока по горизонтали с помощью margin-left: auto и margin-right: auto. В этом случае margin делится на две равные части и элемент центрируется. В случае с выпадающими меню, дочерний список отображается там, где он бы находился без позиционирования.

Итог

Некоторые читатели могут удивиться зачем я трачу время на описание очевидного. При взгляде на готовый пример, механизм авто-позиционирования кажется очевидным, но он не был таким для меня когда я только начал разбираться в принципе работы содержащих блоков и авто-позиционирования. Раз Андрей поднял этот вопрос, для него все это также не было очевидным. Думаю мы не исключение и найдутся те кто подтвердит что все это не является очевидным и для них.

Иногда мы используем те или иные технологии не пытаясь разобраться как они работают. Когда приходится объяснить принцип их работы, мы затрудняемся это сделать. Хотя иногда стоит разобраться в механизме работы используемых приемов.

Я никогда не буду принимать как должное то, как значение auto работает для того или иного свойства и предполагать что оно будет работать так как я ожидаю. Теперь я всегда думаю наперед как будет рассчитываться числовой аналог для auto и как оно будет зависеть от применения значения auto для смежных атрибутов. В большинстве случаев его поведение является таким как я и ожидал, но думаю вероятны случаи когда он будет отличаться от ожидаемого и приведет к интересным результатам.

CSS3 позиционирование под липким меню



Я хочу, чтобы мое меню застряло в верхней части страницы , поэтому я использую position: fixed, но у меня есть проблема с содержимым ниже меню - я не могу его расположить. Например, margin-top не работает, и я не могу понять, почему это происходит.
Вот тебе JSFiddle .

css
Поделиться Источник GoshoPepoto     17 ноября 2015 в 00:53

3 ответа


  • Выпадающее меню установки CSS3

    Если вы наведете курсор на меню User , то меню появится слева = 0. Но, он должен отображаться точно под User 'button'. Как я могу это сделать? (только CSS3)

  • z-index issue - позиционирование треугольника css3 под меню

    Привет и спасибо, что нашли время разобраться в моей проблеме. Я пытаюсь реализовать меню, которое выглядит именно так : Главное здесь-создать эти треугольники для обеих сторон, а затем расположить их под меню, чтобы придать ему эффект 3d. Я заставил его работать, просто найдя на сайте выше, но я...



0

Дайте меню верхнюю позицию 0

#menu{ 
    top:0;
}

#content{
    margin-top: 50px;
}

И примените стиль/позиционирование к вашему контенту div с идентификатором или классом. Я использовал id, потому что это то, что вы выбрали, но в наши дни считается лучшей практикой использовать классы для всех стилей. Зарезервируйте использование ID для javascript крючков.

Вот ваше исправление: https://jsfiddle.net/8gjfLe5d/2/

Поделиться Mark Simpson     17 ноября 2015 в 01:03



0

ну, у вас есть пара проблем в вашем коде, во-первых, как сказал @mgiesa, вы должны поставить

top:0;

другая проблема заключается в том, что контент не является допустимым тегом, поскольку он не имеет свойств позиционирования и отображения dafualt, автоматически добавляемых агентом пользователя.

если вы используете .content в качестве класса, у вас не должно быть никаких проблем, как показано этим fiddle

Поделиться javiercf     17 ноября 2015 в 01:09



-1

Вы должны дать меню id a top и left

#menu{
  position:fixed;
  top:0;
  left:0;
  width:100%;
  height:50px;
}

редактировать: это как-то связано с тегом содержимого

https://jsfiddle. net/wgg9bkmr/2/

Поделиться mgiesa     17 ноября 2015 в 00:57


  • iOS UITableView заголовок с липким меню

    Я хочу создать UITableView со складывающимся видом сверху и липким меню. Чтобы показать что именно я имею в виду я сделал 3 изображения: Я думал, что сделаю UITableViewController и помещу вид над столом, но я не знаю, как реализовать липкое меню. Каков наилучший способ добиться этого?

  • Удалите пространство между липким меню и изображением

    Мне не нужно никакого пространства между липким меню и изображением. Что не так с моим кодом? вот эта ссылка: http://liveweave.com/0M2mU9 Большое спасибо.


Похожие вопросы:


сделать меню wordpress липким при прокрутке

Здравствуйте, я пытаюсь сделать меню wordpress липким на прокрутке. Вот что я имею в виду в практическом плане http://dev. thegabrielmethod.com/ -это главное меню, которое пока не является липким...


Позиционирование Мобильного Меню

Я создаю свой первый шаблон, используя HubSpot COS. Я пытаюсь реализовать мобильное меню для моего адаптивного меню. У меня есть меню, в которое я добавил пользовательский class =custom-menu-primary...


Занавес js с липким меню

Моя цель-сделать простой веб-макет одной страницы с эффектом занавеса и липким меню на нем. Я использовал curtain.js lib для достижения эффекта curtain и этот простой учебник для того, чтобы сделать...


Выпадающее меню установки CSS3

Если вы наведете курсор на меню User , то меню появится слева = 0. Но, он должен отображаться точно под User 'button'. Как я могу это сделать? (только CSS3)


z-index issue - позиционирование треугольника css3 под меню

Привет и спасибо, что нашли время разобраться в моей проблеме. Я пытаюсь реализовать меню, которое выглядит именно так : Главное здесь-создать эти треугольники для обеих сторон, а затем расположить. ..


iOS UITableView заголовок с липким меню

Я хочу создать UITableView со складывающимся видом сверху и липким меню. Чтобы показать что именно я имею в виду я сделал 3 изображения: Я думал, что сделаю UITableViewController и помещу вид над...


Удалите пространство между липким меню и изображением

Мне не нужно никакого пространства между липким меню и изображением. Что не так с моим кодом? вот эта ссылка: http://liveweave.com/0M2mU9 Большое спасибо.


Фиксирующие элементы под липким элементом

Я использую Bootstrap 4. У меня есть заголовок , под ним навигационная панель, которая является липким верхом . Ниже у меня есть ряд из 2 столбцов . В левом столбце я хочу, чтобы заголовок оставался...


Сделайте отзывчивое меню липким

Я пытаюсь создать липкое меню, которое будет реагировать. Я могу заставить работать липкое меню, и я могу заставить работать адаптивное меню (создает меню бургеров на мобильном устройстве), но я не. ..


Почему выпадающий список идет под липким элементом?

У меня есть таблица, в которой последние два столбца фиксируются position = sticky, потому что мне нужно было удалить их из прокрутки. Мне нужно поместить выпадающий список в один фиксированный...

CSS позиционирование (CSS position) // «Фрилансер по жизни»

StaticПо умолчанию

Relative +top,left

Relative +z-index

Absolute+ position: relative; у родителя +top,left

Absolute+top,left

Fixed+width: 100%;+top,left

Sticky*

.block-1

.block-2

.block-3

Элементы отображаются как обычно. Использование свойств left, top, right, bottom и z-index не приводит к каким-либо результатам.

CSS код:

.mainblock{

background-color: #eee; position: static;

}

.block-1{

position: static;

}

.block-2{

position: static;

}

.block-3{

position: static;

}

.block-1

.block-2

.block-3

Положение элемента устанавливается относительно его исходного положения в коде. Добавление свойств left, top, right и bottom изменяет позицию элемента и сдвигает его в ту или иную сторону от первоначального расположения.

CSS код:

.mainblock{

background-color: #eee;

}

.block-1{

}

.block-2{

position: relative; top: 30px; left: 20px;

}

.block-3{

}

.block-1

.block-2

.block-3

Каждый элемент может находиться как ниже, так и выше других объектов веб-страницы, их размещением по z-оси и управляет z-index. Это свойство работает только для элементов, у которых значение position задано как absolute, fixed или relative.

CSS код:

. mainblock{

background-color: #eee;

}

.block-1{

}

.block-2{

position: relative; top: 30px; left: 20px;

}

.block-3{

position: relative; z-index: 2;

}

.block-1

.block-2

.block-3

Элемент якобы вырывается из кода и зависайт в воздухе. Он перестает влиять на остальные элементы. Добавление свойств left, top, right и bottom изменяет позицию элемента и сдвигает его в ту или иную сторону относительно родителя у колого задан параметр position: relative;

CSS код:

. mainblock{

background-color: #eee; position: relative;

}

.block-1{

}

.block-2{

position: absolute; top: 30px; left: 20px;

}

.block-3{

}

.block-1

.block-2

.block-3

Элемент якобы вырывается из кода и зависайт в воздухе. Он перестает влиять на остальные элементы. Добавление свойств left, top, right и bottom изменяет позицию элемента и сдвигает его в ту или иную сторону относительно родителя у колого задан параметр position: relative; Если такого нет то элемент позиционируется относительно окна браузера.

CSS код:

.mainblock{

background-color: #eee;

}

.block-1{

}

.block-2{

position: absolute; top: 30px; left: 20px;

}

.block-3{

}

.block-1

.block-2

.block-3

Элемент якобы вырывается из кода и зависайт в воздухе. Фиксируется, то есть не скролится вместе с содержимым. Он перестает влиять на остальные элементы. Добавление свойств left, top, right и bottom изменяет позицию элемента и сдвигает его в ту или иную сторону относительно окна браузера.

CSS код:

.mainblock{

background-color: #eee;

}

.block-1{

}

.block-2{

position: fixed; width: 100%; top: 0px; left: 0px;

}

.block-3{

}

.block-1

.block-2

.block-3

Это гибридное сочетание значений static и fixed. Изначально єлемент ведет себя как static но после того как скролл доходит до его границы он становиться fixed и прилипает к указанной позиции top или bottom.

* Смотри поддержку браузерами

** Для демонстрации работы нужно проскролить контент внутри блока

CSS код:

. mainblock{

background-color: #eee;

}

.block-1{

}

.block-2{

position: sticky; top: 0px;

}

.block-3{

}

position | CSS (Примеры)

Свойство position устанавливает способ позиционирования элемента относительно окна браузера или других объектов на веб-странице.

Позиционирование

Синтаксис

/* Keyword values */
position: static;
position: relative;
position: absolute;
position: fixed;
position: sticky;

/* Global values */
position: inherit;
position: initial;
position: unset;

Значения

absolute
Абсолютное позиционирование. Указывает, что элемент абсолютно позиционирован, при этом другие элементы отображаются на веб-странице словно абсолютно позиционированного элемента нет. Положение элемента задаётся свойствами left, top, right и bottom, также на положение влияет значение свойства position родительского элемента. Так, если у родителя значение position установлено как static или родителя нет, то отсчёт координат ведётся от края окна браузера. Если у родителя значение position задано как relative, то отсчёт координат ведётся от края родительского элемента.
fixed
Фиксированное позиционирование. По своему действию это значение близко к absolute, но в отличие от него привязывается к указанной свойствами left, top, right и bottom точке на экране и не меняет своего положения при прокрутке веб-страницы.
relative
Относительное позиционирование. Положение элемента устанавливается относительно его исходного места. Добавление свойств left, top, right и bottom изменяет позицию элемента и сдвигает его в ту или иную сторону от первоначального расположения.
static
Статичное позиционирование. Элементы отображаются как обычно. Использование свойств left, top, right и bottom не приводит к каким-либо результатам.
sticky
Это сочетание относительного и фиксированного позиционирования. Элемент рассматривается как позиционированный относительно, пока он не пересекает определённый порог, после чего рассматривается как фиксированный. Обычно применяется для фиксации заголовка на одном месте, пока содержимое, к которому относится заголовок, прокручивается на странице.

Примечание

Браузер Safari поддерживает значение -webkit-sticky.

Значение по-умолчанию: static

Применяется ко всем элементам

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

Поддержка браузерами

position: fixed:

Can I Use css-fixed? Data on support for the css-fixed feature across the major browsers from caniuse. com.

position: sticky:

Can I Use css-sticky? Data on support for the css-sticky feature across the major browsers from caniuse.com.

Описание и примеры

<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8" />
    <title>position</title>
    <style>
      .layer1 {
        position: relative; /* Относительное позиционирование */
        background: #f0f0f0; /* Цвет фона */
        height: 200px; /* Высота блока */
      }
      .layer2 {
        position: absolute; /* Абсолютное позиционирование */
        bottom: 15px; /* Положение от нижнего края */
        right: 15px; /* Положение от правого края */
        line-height: 1px;
      }
    </style>
  </head>
  <body>
    <div>
      <div>
        <img src="image/girl.jpg" alt="Девочка" />
      </div>
    </div>
  </body>
</html>

Ссылки

CSS свойство позиции


Пример

Позиционируйте элемент

:

h3 {
позиция: абсолютная;
слева: 100 пикселей;
верх: 150 пикселей;
}

Попробуй сам "

Дополнительные примеры "Попробуйте сами" ниже.


Определение и использование

Позиция Свойство определяет тип метода позиционирования, используемый для элемент (статический, относительный, абсолютный, фиксированный или липкий).

Значение по умолчанию: статический
Унаследовано:
Анимируемое: нет. Прочитать о animatable
Версия: CSS2
Синтаксис JavaScript: объект .style.position = "absolute" Попробуй это

Поддержка браузера

Числа в таблице указывают первую версию браузера, полностью поддерживающую свойство.

Объект
позиция 1,0 7,0 1,0 1,0 4,0

Примечание. Прикрепленное значение не поддерживается в Internet Explorer, Edge 15 и более ранних версиях.



Синтаксис CSS

позиция: статическая | абсолютная | фиксированная | относительная | липкая | начальная | наследование;

Значения собственности

Значение Описание Играй
статический Значение по умолчанию.Элементы отображаются в том порядке, в котором они отображаются в потоке документов Играй »
абсолютное Элемент позиционируется относительно своего первого позиционированного (не статического) элемента-предка Играй »
фиксированная Элемент расположен относительно окна браузера Играй »
родственник Элемент позиционируется относительно своего нормального положения, поэтому "left: 20px" добавляет 20 пикселей к ЛЕВОЙ позиции элемента Играй »
липкий Элемент позиционируется в зависимости от положения прокрутки пользователя.

Прикрепленный элемент переключается между относительно и фиксированным , в зависимости от положения прокрутки.Он позиционируется относительно, пока не будет достигнута заданная позиция смещения во вьюпорте - затем он «застревает» на месте (например, position: fixed).

Примечание. Не поддерживается в IE / Edge 15 или более ранних версиях. Поддерживается в Safari с версии 6.1 с префиксом -webkit-.
Попробуй »
начальный Устанавливает для этого свойства значение по умолчанию. Читать примерно начальные Играй »
наследовать Наследует это свойство от своего родительского элемента.Читать про наследство

Другие примеры

Пример

Как расположить элемент относительно его нормального положения:

h3.pos_left {
позиция: относительная;
слева: -20 пикселей;
}

h3. pos_right {
позиция: относительная;
слева: 20 пикселей;
}

Попробуй сам "

Пример

Больше позиционирования:

# parent1 {
позиция: статическая;
граница: сплошной синий 1px;
ширина: 300 пикселей;
высота: 100 пикселей;
}

# child1 {
позиция: абсолютный;
граница: сплошной красный 1px;
верх: 70 пикселей;
справа: 15 пикселей;
}

# parent2 {
положение: относительное;
граница: сплошной синий 1px;
ширина: 300 пикселей;
высота: 100 пикселей;
}

# child2 {
позиция: абсолютная;
граница: сплошной красный 1px;
верх: 70 пикселей;
справа: 15 пикселей;
}

Попробуй сам "

связанные страницы

Учебник

CSS: позиционирование CSS

Ссылка

HTML DOM: позиция собственности



позиция - CSS: каскадные таблицы стилей

Свойство position CSS устанавливает, как элемент располагается в документе. Свойства верхний , правый , нижний и левый определяют окончательное расположение позиционированных элементов.

Исходный код этого интерактивного примера хранится в репозитории GitHub. Если вы хотите внести свой вклад в проект интерактивных примеров, клонируйте https://github.com/mdn/interactive-examples и отправьте нам запрос на перенос.

Свойство position указано как одно ключевое слово, выбранное из списка значений ниже.

Значения

статические
Элемент размещается в соответствии с обычным потоком документа. Свойства верхний , правый , нижний , левый и z-index свойства не влияют на . Это значение по умолчанию.
родственник
Элемент позиционируется в соответствии с нормальным потоком документа, а затем смещается на относительно себя на основе значений вверху , справа , внизу и слева . Смещение не влияет на положение других элементов; таким образом, пространство, отведенное для элемента в макете страницы, такое же, как если бы позиция была static .
Это значение создает новый контекст наложения, когда значение z-index не равно auto . Его влияние на элементы table - * - group , table-row , table-column , table-cell и table-caption не определено.
абсолютное
Элемент удаляется из обычного потока документов, и пространство для него не создается в макете страницы.Он позиционируется относительно ближайшего предка, если таковой имеется; в противном случае он размещается относительно исходного содержащего блока. Его окончательное положение определяется значениями вверху , справа , внизу и слева .
Это значение создает новый контекст наложения, когда значение z-index не равно auto . Поля абсолютно позиционированных блоков не сжимаются с другими полями.
фиксированный
Элемент удаляется из обычного потока документов, и пространство для него не создается в макете страницы.Он позиционируется относительно исходного содержащего блока, установленного окном просмотра, за исключением случаев, когда один из его предков имеет свойство преобразование , перспективу или фильтр , установленное на что-то иное, чем нет (см. Спецификацию преобразований CSS) , и в этом случае этот предок ведет себя как содержащий блок. (Обратите внимание, что существуют несоответствия браузера с перспективой и фильтром , способствующим формированию блока.) Его конечное положение определяется значениями верхний , правый , нижний и левый .
Это значение всегда создает новый контекст наложения. В печатных документах элемент помещается в одинаковое положение на на каждой странице .
липкий
Элемент позиционируется в соответствии с нормальным потоком документа, а затем смещается относительно своего ближайшего предка с прокруткой и содержащего блока (ближайшего предка на уровне блока), включая элементы, связанные с таблицей, на основе значений top , справа , снизу и слева .Смещение не влияет на положение других элементов.
Это значение всегда создает новый контекст наложения. Обратите внимание, что липкий элемент «прилипает» к своему ближайшему предку, у которого есть «механизм прокрутки» (создается, когда переполнение скрыто , прокрутка , авто или наложение ), даже если этот предок не t ближайший предок, выполняющий прокрутку. Это эффективно предотвращает любое «липкое» поведение (см. Проблему GitHub на W3C CSSWG).

Типы позиционирования

  • Позиционированный элемент - это элемент, для которого вычисленное значение позиции является либо относительным , абсолютным , фиксированным или липким . (Другими словами, это что угодно, кроме static .)
  • Относительно позиционированный элемент - это элемент, для которого вычисленное значение позиции равно относительно . Свойства верхний и нижний определяют вертикальное смещение от его нормального положения; свойства left и right определяют смещение по горизонтали.
  • Абсолютно позиционированный элемент - это элемент, для которого вычисленное значение позиции равно абсолютное или фиксированное . Свойства верхний , правый , нижний и левый определяют смещения от краев содержащего блока элемента. (Содержащий блок является предком, относительно которого позиционируется элемент.) Если у элемента есть поля, они добавляются к смещению. Элемент устанавливает новый контекст форматирования блока (BFC) для своего содержимого.
  • Элемент с липким позиционированием - это элемент, для которого вычисленное значение позиции равно липкое . Он считается относительно позиционированным до тех пор, пока содержащий его блок не пересечет указанный порог (например, установка top на значение, отличное от auto) в его корне потока (или в контейнере, в котором он прокручивается), после чего он рассматривается как «застрявший» до тех пор, пока встречает противоположный край содержащего его блока.

В большинстве случаев абсолютно позиционированные элементы с высотой и шириной , установленной на авто , имеют размер, соответствующий их содержимому.Однако незамещенные, абсолютно позиционированные элементы можно сделать так, чтобы они заполняли доступное вертикальное пространство, указав как верхний , так и нижний и оставив высоту неопределенной (то есть авто ). Их также можно сделать так, чтобы они заполняли доступное горизонтальное пространство, указав слева и справа и оставив ширину как авто .

За исключением только что описанного случая (абсолютно позиционированные элементы, заполняющие доступное пространство):

  • Если указаны и верхний , и нижний (технически, не авто ), выигрывает верхний .
  • Если указаны оба left и right , left побеждает, когда направление равно ltr (английский, горизонтальный японский и т. Д.) И right выигрывает, когда направление равно rtl (персидский, Арабский, иврит и др.).

Убедитесь, что элементы, позиционированные с абсолютным значением или фиксированным значением , не закрывают другой контент, когда страница масштабируется для увеличения размера текста.

Производительность и доступность

Прокрутка элементов, содержащих фиксированных или липких содержимого, может вызвать проблемы с производительностью и доступностью.Когда пользователь прокручивает страницу, браузер должен перерисовать закрепленный или фиксированный контент в новом месте. В зависимости от содержимого, которое необходимо перерисовать, производительности браузера и скорости обработки устройства, браузер может не справиться с перерисовкой со скоростью 60 кадра в секунду , вызывая проблемы доступности для людей с повышенной чувствительностью и дрянь для всех. Одно из решений - добавить will-change: transform к позиционированным элементам, чтобы отобразить элемент на его собственном слое, улучшив скорость перерисовки и, следовательно, улучшив производительность и доступность.

  статический | родственник | абсолютный | липкий | фиксированный  

Относительное позиционирование

Относительно позиционированные элементы смещены на заданную величину от их нормального положения в документе, но без влияния смещения на другие элементы. В приведенном ниже примере обратите внимание, как другие элементы размещены, как если бы «Два» занимали пространство своего обычного расположения.

HTML
  
Один
Два
Три
Четыре
CSS
  * {
  размер коробки: рамка-рамка;
}

.box {
  дисплей: встроенный блок;
  ширина: 100 пикселей;
  высота: 100 пикселей;
  фон: красный;
  цвет белый;
}

#два {
  положение: относительное;
  верх: 20 пикселей;
  слева: 20 пикселей;
  фон: синий;
}
  

Абсолютное позиционирование

Элементы, расположенные относительно друг друга, остаются в обычном потоке документа. Напротив, абсолютно позиционированный элемент выводится из потока; таким образом, другие элементы позиционируются так, как если бы его не было. Абсолютно позиционированный элемент позиционируется относительно своего ближайшего предка (т.е.е. ближайший предок, который не является static ). Если позиционированный предок не существует, он позиционируется относительно ICB (начальный содержащий блок - см. Также определение W3C), который является содержащим блоком корневого элемента документа.

HTML
  

Абсолютное позиционирование

Я элементарный элемент базового уровня. Соседние элементы уровня блока располагаются на новых строках ниже меня.

По умолчанию мы покрываем 100% ширины нашего родительского элемента, и мы достигаем высоты нашего дочернего содержимого.Наша общая ширина и высота - это наше содержимое + отступ + ширина / высота границы.

Нас разделяют наши поля. Из-за сжатия поля мы разделяем ширину одного из наших полей, а не обоих.

встроенные элементы , подобные этому и this , располагаются на одной строке друг с другом и смежными текстовыми узлами, если на той же строке есть место. Переполняющиеся встроенные элементы переносятся на новую строку, если это возможно - как эта, содержащая текст , или просто переходите к новой строке, если нет, как это будет с этим изображением:

CSS
  * {
  размер коробки: рамка-рамка;
}

body {
  ширина: 500 пикселей;
  маржа: 0 авто;
}

п {
  фон: цвет морской волны;
  граница: сплошной синий цвет 3px;
  отступ: 10 пикселей;
  маржа: 10 пикселей;
}

span {
  фон: красный;
  граница: сплошной черный 1px;
}

.positioned {
  позиция: абсолютная;
  фон: желтый;
  верх: 30 пикселей;
  слева: 30 пикселей;
}  
Результат

Фиксированное позиционирование

Фиксированное позиционирование похоже на абсолютное позиционирование, за исключением того, что содержащий блок элемента является начальным содержащим блоком, установленным окном просмотра , если только какой-либо предок не имеет преобразование , перспективу или фильтр свойство установить значение, отличное от none (см. Спецификацию преобразований CSS), что затем заставляет этого предка занять место элементов, содержащих блок. Это можно использовать для создания «плавающего» элемента, который остается в одном положении независимо от прокрутки. В приведенном ниже примере поле «Один» зафиксировано на расстоянии 80 пикселей от верхнего края страницы и 10 пикселей от левого края. Даже после прокрутки он остается на том же месте относительно области просмотра.

HTML
  

Lorem ipsum dolor sit amet, conctetur adipiscing elit. Nam congue Tortor Eget pulvinar lobortis. Vestibulum ante ipsum primis в faucibus orci luctus et ultrices posuere cubilia Curae; Nam ac dolor augue.Pellentesque mi mi, laoreet et dolor sit amet, ultrices varius risus. Nam vitae iaculis elit. Aliquam mollis interdum libero. Sed sodales placerat egestas. Vestibulum ut arcu aliquam purus viverra dictum vel sit amet mi. Duis nisl mauris, aliquam sit amet luctus eget, dapibus in enim. Sed velit augue, pretium a sem aliquam, congue porttitor toror. Sed tempor nisl a lorem conquat, id maximus erat aliquet. Sed sagittis porta libero sed condimentum. Aliquam finibus lectus nec ante congue rutrum.Curabitur quam quam, accumsan id ultrices ultrices, tempor et tellus.

Lorem ipsum dolor sit amet, conctetur adipiscing elit. Nam congue Tortor Eget pulvinar lobortis. Vestibulum ante ipsum primis в faucibus orci luctus et ultrices posuere cubilia Curae; Nam ac dolor augue. Pellentesque mi mi, laoreet et dolor sit amet, ultrices varius risus. Nam vitae iaculis elit. Aliquam mollis interdum libero. Sed sodales placerat egestas. Vestibulum ut arcu aliquam purus viverra dictum vel sit amet mi.Duis nisl mauris, aliquam sit amet luctus eget, dapibus in enim. Sed velit augue, pretium a sem aliquam, congue porttitor toror. Sed tempor nisl a lorem conquat, id maximus erat aliquet. Sed sagittis porta libero sed condimentum. Aliquam finibus lectus nec ante congue rutrum. Curabitur quam quam, accumsan id ultrices ultrices, tempor et tellus.

Один
CSS
  * {
  размер коробки: рамка-рамка;
}

. box {
  ширина: 100 пикселей;
  высота: 100 пикселей;
  фон: красный;
  цвет белый;
}

#один {
  положение: фиксированное;
  верх: 80 пикселей;
  слева: 10 пикселей;
  фон: синий;
}

.outer {
  ширина: 500 пикселей;
  высота: 300 пикселей;
  переполнение: прокрутка;
  отступ слева: 150 пикселей;
}
  
Результат

Липкое позиционирование

Липкое позиционирование можно рассматривать как гибрид относительного и фиксированного позиционирования. Элемент с фиксированным позиционированием считается относительно позиционированным до тех пор, пока он не пересечет указанный порог, после чего он считается фиксированным, пока не достигнет границы своего родителя.Например ...

  #one {position: sticky; верх: 10 пикселей; }  

... позиционирует элемент с идентификатором относительно до тех пор, пока область просмотра не будет прокручена таким образом, чтобы элемент находился на расстоянии менее 10 пикселей от верха. За пределами этого порога элемент будет зафиксирован на 10 пикселей сверху.

Обычно липкое позиционирование используется для заголовков в алфавитном списке. Заголовок «B» будет отображаться чуть ниже элементов, начинающихся с «A», пока они не будут прокручены за пределы экрана.Вместо того, чтобы перемещаться за пределы экрана вместе с остальным контентом, заголовок «B» будет оставаться закрепленным в верхней части области просмотра до тех пор, пока все элементы «B» не будут прокручены за пределы экрана, после чего он будет закрыт буквой «C» заголовок и так далее.

Вы должны указать порог по крайней мере с одним из верхний , правый , нижний или левый , чтобы закрепленное позиционирование работало должным образом. В противном случае его нельзя будет отличить от относительного позиционирования.

HTML
  
А
Эндрю В.К.
Аппарат
Arcade Fire
У подъезда
Азиз Ансари
C
Chromeo
Обычный
Свести
Хрустальные замки
Курсив
E
Взрывы в небе
Т
Тед Лео & amp; Фармацевты
Т-Пейн
Трижды
Телевидение по радио
Два галанта
CSS
  * {
  размер коробки: рамка-рамка;
}

dl> div {
  фон: #FFF;
  отступ: 24px 0 0 0;
}

dt {
  фон: # B8C1C8;
  нижняя граница: сплошной 1px # 989EA4;
  border-top: 1px solid # 717D85;
  цвет: #FFF;
  шрифт: полужирный 18px / 21px Helvetica, Arial, sans-serif;
  маржа: 0;
  отступ: 2px 0 0 12px;
  позиция: -webkit-sticky;
  положение: липкое;
  верх: -1px;
}

dd {
  шрифт: полужирный, 20 пикселей / 45 пикселей, Helvetica, Arial, без засечек;
  маржа: 0;
  отступ: 0 0 0 12 пикселей;
  белое пространство: nowrap;
}

dd + dd {
  верхняя граница: сплошной 1px #CCC;
}
  
Результат

Таблицы BCD загружаются только в браузере

CSS Positioning 101 - A List Apart

Если вы фронтенд-разработчик или дизайнер, который любит кодировать, макеты на основе CSS лежат в основе вашей работы. В том, что может быть освежением для некоторых или даже «а-ха!» для других давайте посмотрим на свойство CSS position , чтобы увидеть, как мы можем использовать его для создания совместимых со стандартами макетов CSS без таблиц.

Продолжение статьи ниже

CSS-позиционирование часто понимают неправильно. Иногда, в ярости от исправления ошибок, мы применяем разные значения позиции к данному селектору, пока не получим тот, который работает. Это утомительный процесс, который может работать какое-то время, но нам следует знать , почему , указав что-то вроде position: relative , может исправить вашу ошибку макета.Я надеюсь, что мы сможем узнать о значениях и поведении свойства position и, что наиболее важно, о том, как значение может повлиять на вашу разметку.

Спецификация CSS предлагает нам пять свойств position : static , relative , absolute , fixed и наследу . Каждое свойство служит определенной цели. Понимание этой цели - ключ к освоению макетов на основе CSS.

Получить с потоком # section2

Во-первых, давайте сделаем шаг назад, чтобы узнать мир, в котором мы работаем.Как и в нашем реальном мире, в CSS мы работаем в рамках границ. В CSS эта граница называется нормальным потоком. Согласно спецификации CSS 2.1:

Блоки в нормальном потоке принадлежат контексту форматирования, который может быть блочным или встроенным, но не обоими одновременно. Блок-боксы участвуют в контексте форматирования блока. Встроенные блоки участвуют во встроенном контексте форматирования.

Думайте о «шкатулке», описанной в спецификации, как о деревянном бруске, похожем на те, с которыми вы играли в юности.Теперь представьте себе нормальный поток как закон, подобный закону всемирного тяготения. Нормальный поток документа - это то, как ваши элементы складываются друг над другом, сверху вниз, в том порядке, в котором они появляются в вашей разметке. Вы, возможно, помните, как складывали блоки с алфавитом в гигантские башни: обычный поток ничем не отличается от тех деревянных блоков, которые связаны законом гравитации. В детстве у вас был один блок поверх другого; в вашей разметке один элемент за другим. Однако в детстве вы не могли придать этим блокам свойства, которые противоречили закону гравитации.Внезапно CSS кажется намного круче, чем эти блоки алфавита.

Статическое и относительное - здесь ничего нового # section3

Свойства static и относительно position ведут себя как ваши детские блоки - они складываются, как и следовало ожидать. Обратите внимание, что static - это значение по умолчанию для позиции элемента, если вы не сможете применить какое-либо другое значение. Если в вашем коде есть три статически позиционированных элемента, они, как и следовало ожидать, будут складываться один поверх другого.Давайте посмотрим на пример с тремя элементами, каждый из которых имеет позицию , , значение static :

  # box_1 {
положение: статическое;
ширина: 200 пикселей;
высота: 200 пикселей;
фон: # ee3e64;
}

# box_2 {
положение: статическое;
ширина: 200 пикселей;
высота: 200 пикселей;
фон: # 44accf;
}

# box_3 {
положение: статическое;
ширина: 200 пикселей;
высота: 200 пикселей;
фон: # b7d84b;
}  

В примере A вы можете увидеть три элемента, сложенные в виде простой башни. Очаровательно, не правда ли? Это блочный дом 101.Поздравляю!

Вы можете использовать значение static для простых макетов с одним столбцом, где каждый элемент должен располагаться поверх следующего. Если вы хотите начать смещение этих элементов, используя такие свойства смещения, как верхний , правый , нижний и левый , вам не повезло. Эти свойства недоступны для статического элемента . Фактически, статический элемент даже не может создать новую систему координат для дочерних элементов.Подождите. Какая? Вы потеряли меня в системе координат . Роджер, Роджер. Давайте объясним, используя относительное значение .

Относительно расположенные элементы ведут себя так же, как статически расположенные элементы; они хорошо играют с другими, хорошо складываются и не вызывают шума. Трудно поверить, правда? Взгляните на наш предыдущий пример. На этот раз мы применили относительное значение :

  # box_1 {
положение: относительное;
ширина: 200 пикселей;
высота: 200 пикселей;
фон: # ee3e64;
}

# box_2 {
положение: относительное;
ширина: 200 пикселей;
высота: 200 пикселей;
фон: # 44accf;
}

# box_3 {
положение: относительное;
ширина: 200 пикселей;
высота: 200 пикселей;
фон: # b7d84b;
}  

Пример B доказывает, что относительно позиционированные элементы ведут себя точно так же, как статически позиционированные элементы. Возможно, вы не знаете, что элементы с относительным значением положения похожи на Кларка Кента - они скрывают гораздо большие силы, чем их статические братья и сестры.

Для начала, мы можем настроить относительно позиционированный элемент со свойствами смещения: верхний , правый , нижний и левый . Используя разметку из нашего предыдущего примера, давайте добавим позицию смещения к # box_2 :

  # box_2 {
положение: относительное;
слева: 200 пикселей;
ширина: 200 пикселей;
высота: 200 пикселей;
фон: # 44accf;
}  

Пример C показывает это положение относительно в действии.Наши три блока хорошо сложены, но на этот раз синий блок ( # box_2 ) выдвинут на 200 пикселей слева. Здесь мы начинаем подчинять закон всемирного тяготения своей воле. Синий блок все еще находится в потоке документа - элементы накладываются друг на друга - но обратите внимание на зеленый блок ( # box_3 ) внизу. Он находится под синим блоком, хотя синий блок не находится прямо над ним. Когда вы используете свойство смещения для смещения относительно позиционированного элемента, оно не влияет на последующие элементы.Зеленый прямоугольник по-прежнему расположен так, как если бы синий прямоугольник находился в своем несмещенном положении. Попробуйте это с помощью башни из алфавитного блока.

Создание системы координат для дочерних элементов - еще одна суперспособность свойства относительного позиционирования. Система координат является точкой отсчета для офсетных свойств. Вспомните, как в примере C наш синий блок ( # box_2 ) не находится внутри каких-либо других элементов, поэтому система координат, которую он использует для смещения себя на 200 пикселей слева, - это сам документ.Если мы разместим элемент # box_2 внутри # box_1 , мы получим другой результат, так как # box_2 будет позиционировать себя как относительно относительно системы координат из # box_1 . В следующем примере мы не будем изменять какой-либо CSS, мы скорректируем наш HTML, чтобы переместить # box_2 внутрь # box_1 :

.
  

Пример D показывает нашу новую разметку. Из-за новой системы координат синий блок измеряет свое смещение на 200 пикселей слева от красного блока ( # box_1 ) вместо документа.Эта практика более распространена с элементами, установленными в положение : абсолютный - так, как вы хотели бы строить башни, когда были моложе.

Абсолютный - в любом месте и в любое время # section4

Если относительное значение действует как Супермен, то абсолютное значение отражает Начало - место, где вы создаете свой собственный мир. В отличие от значений static и относительных , абсолютно позиционированный элемент удаляется из нормального потока.Это означает, что вы можете разместить его где угодно, и он не повлияет на или не будет затронут каким-либо другим элементом в потоке. Думайте об этом как об элементе с гигантской полосой на липучке на спине. Просто скажи ему, куда приклеить, и он прилипнет. Точно так же, как относительное значение , абсолютно позиционированные элементы реагируют на свойства смещения для позиционирования. Вы можете установить для элемента значение top: 100px и left: 200px; , и этот элемент будет располагаться ровно на 100 пикселей сверху и на 200 пикселей слева от документа.Давайте посмотрим на пример с использованием четырех элементов:

  # box_1 {
позиция: абсолютная;
верх: 0;
слева: 0;
ширина: 200 пикселей;
высота: 200 пикселей;
фон: # ee3e64;
}
# box_2 {
позиция: абсолютная;
верх: 0;
справа: 0;
ширина: 200 пикселей;
высота: 200 пикселей;
фон: # 44accf;
}
# box_3 {
позиция: абсолютная;
внизу: 0;
слева: 0;
ширина: 200 пикселей;
высота: 200 пикселей;
фон: # b7d84b;
}
# box_4 {
позиция: абсолютная;
внизу: 0;
справа: 0;
ширина: 200 пикселей;
высота: 200 пикселей;
фон: # ebde52;
}  

Пример E показывает четыре поля, каждое в углу окна браузера. Поскольку мы установили для каждого поля значение позиции абсолютное значение , мы по существу прикрепили прямоугольник к каждому углу окна браузера. По мере изменения размера браузера эти поля останутся в своих углах. Если вы уменьшите окно браузера так, чтобы поля перекрывались, вы заметите, что никакого взаимодействия не происходит - это потому, что они выходят за рамки обычного потока документа.

Так же, как относительных элементов, абсолютных элементов создают новую систему координат для дочерних элементов.Пример F расширяет пример E с оранжевым элементом, установленным внутри каждого блока. Обратите внимание, что координаты смещения относятся к каждому родительскому элементу.

Чтобы не уступать другим значениям свойства position , абсолютное значение предлагает некоторые действительно интересные функциональные возможности с использованием свойства offset. Используйте два или все четыре свойства смещение , и вы можете растянуть элемент, не определяя ширину или высоту - он связан только с его родительским элементом или самим документом. Давайте посмотрим на это в действии. Рассмотрим следующий код:

  #box_a {
позиция: абсолютная;
верх: 10 пикселей;
вправо: 10 пикселей;
внизу: 10 пикселей;
слева: 10 пикселей;
фон: красный;
}
#box_b {
позиция: абсолютная;
верх: 20 пикселей;
вправо: 20 пикселей;
внизу: 20 пикселей;
слева: 20 пикселей;
фон: белый;
}  

В примере G мы создали смещение границы документа на 10 пикселей, и оно полностью плавно по мере изменения размера документа - все с абсолютным позиционированием и смещениями . В другом примере мы можем создать макет с двумя столбцами, который заполняет всю высоту документа.Вот CSS:

  # box_1 {
позиция: абсолютная;
верх: 0;
справа: 20%;
внизу: 0;
слева: 0;
фон: # ee3e64;
}

# box_2 {
позиция: абсолютная;
верх: 0;
справа: 0;
внизу: 0;
осталось: 80%;
фон: # b7d84b;
}  

Пример H показывает полноэкранный макет из двух столбцов. Хотя это, вероятно, не лучший подход к двухколоночной компоновке, он все же показывает мощность, которую выдерживает абсолютное значение . Проявив творческий подход, вы можете найти несколько полезных приложений для позиции : абсолютная .Подобные уловки используют только одно значение смещения. Например:

  # box_1 {
ширина: 200 пикселей;
высота: 200 пикселей;
фон: # ee3e64;
}
# box_2 {
позиция: абсолютная;
слева: 100 пикселей;
ширина: 200 пикселей;
высота: 200 пикселей;
фон: # 44accf;
}  

В примере h3 сфокусируйтесь на синем блоке ( # box_2 ). Обратите внимание, как я использую только одно смещение, left: 100px; . Это позволяет элементу # box_2 сохранять верхний край и по-прежнему сдвигать на 100 пикселей влево.Если бы мы применили второе смещение к верху, мы бы увидели, что наш синий блок ( # box_2 ) вытянут в верхнюю часть документа. Смотрите здесь, в примере h4:

  # box_2 {
позиция: абсолютная;
верх: 0;
слева: 100 пикселей;
ширина: 200 пикселей;
высота: 200 пикселей;
фон: # 44accf;
}  

Исправлено - всегда есть # section5

Элемент с положением : фиксированный. разделяет все правила абсолютно позиционированного элемента, за исключением того, что область просмотра (окно браузера / устройства) позиционирует фиксированный элемент в отличие от любого родительского элемента.Кроме того, фиксированный элемент не прокручивается вместе с документом. Он остается, ну… исправленным. Давайте посмотрим на пример:

  # box_2 {
положение: фиксированное;
внизу: 0;
слева: 0;
справа: 0;
}  

Пример I показывает нижний колонтитул с текстом об авторских правах в нем как фиксированный элемент . Во время прокрутки обратите внимание, что он не двигается. Обратите внимание, что свойства смещения слева и справа установлены на ноль. Поскольку фиксированное значение ведет себя аналогично абсолютному значению , мы можем растянуть ширину элемента, чтобы он соответствовал области просмотра, при этом фиксируя элемент внизу, используя bottom: 0; . Будьте осторожны с фиксированным значением : поддержка в старых браузерах в лучшем случае неоднородна. Например, более старые версии Internet Explorer отображают фиксированных элементов как статических элементов. И теперь вы знаете, что статических элементов не ведут себя как фиксированных элементов, верно? Если вы планируете использовать фиксированных элементов в макете, есть несколько решений, которые могут помочь заставить ваш элемент вести себя должным образом в браузерах, которые не поддерживают фиксированное значение .

Inherit - Нечто напрасно # section6

Как я упоминал в начале этой статьи, для свойства position доступно пять значений. Пятое значение - наследовать . Он работает так, как следует из названия: элемент наследует значение своего родительского элемента. Как правило, элементы свойства position не наследуют естественным образом значения своих родителей - статическое значение назначается, если не задано значение position . В конечном итоге вы можете ввести , наследовать или значение родительского элемента и получить тот же результат.

В действии # section7

Все эти разговоры и никаких действий. Давайте посмотрим на реальный пример веб-сайта, на котором используются все значения позиций. В примере J показан типичный макет веб-сайта с заголовком, навигацией, содержимым и нижним колонтитулом. Давайте пройдемся по каждому элементу, обсудим его свойство position и почему мы выбрали это свойство.

Начнем с элемента #container .Это просто содержащий элемент, который я использую для центрирования нашего контента в области просмотра. Элемент #nav - это первый элемент в нашем элементе #container . Элемент position не назначен элементу #nav , поэтому по умолчанию для него установлено значение static . Это нормально: нам не нужно ничего делать для смещения этого элемента или создавать с ним какие-либо новые системы координат. Нам нужно будет сделать это с помощью #content в нашем следующем элементе, поэтому для этого элемента мы применили свойство position , равное относительно .

Поскольку здесь не используются смещения, значение position не оказывает реального влияния на элемент #content , но мы разместили его там, чтобы создать новую систему координат для элемента #callout . Для нашего элемента #callout задано значение position: absolute , а поскольку его родительский элемент, #content установлен в значение relative , свойства смещения, которые мы используем в #callout , основаны на созданных координатах. по # содержание .Элемент #callout использует отрицательное смещение в пикселях 80 пикселей справа, чтобы вытащить элемент за пределы содержащего его родительского элемента. Кроме того, я использовал одну из лучших особенностей абсолютного значения в нашем элементе #callout : установив верхнее и нижнее смещения на 100 пикселей, я растянул элемент #callout на всю высоту документ без смещения 100 пикселей сверху и снизу.

Поскольку элемент #callout имеет абсолютное значение , он не влияет на другие элементы.Поэтому нам нужно добавить отступ к элементу #content , чтобы наши абзацы не пропадали под ним. Установка отступа справа от #content на 250 пикселей позволяет пользователям полностью видеть наш контент. Чтобы поднять заднюю часть, мы добавили нижний колонтитул с фиксированным положением , чтобы он оставался прикрепленным к нижней части страницы. При прокрутке нижний колонтитул остается на месте. Точно так же, как мы добавили отступ к #content , чтобы наши абзацы не пропадали под ним, нам нужно сделать то же самое для элемента #footer , поскольку он является родственником абсолютного значения .Добавление 60 пикселей к нижнему отступу элемента #content гарантирует, что мы сможем прокрутить весь документ и не пропустить какой-либо текст, который обычно был бы скрыт под элементом #footer .

Теперь у нас есть красивый, простой макет с навигацией, некоторым контентом, областью выноски и нижним колонтитулом с использованием статических , относительных , абсолютных и фиксированных элементов. Поскольку мы используем фиксированное значение в этом макете, нам следует применить некоторые методы, чтобы убедиться, что старые браузеры по-прежнему соответствуют нашему дизайну.[Примечание: раньше была ссылка на примеры методов, но с тех пор этот сайт был захвачен вредоносным ПО. Извинения. - Ред. ]

Благодаря мощности position вы можете уверенно и успешно выполнить многие макеты. К счастью, 80% значений свойства position имеют отличную поддержку как в современных, так и в старых браузерах. Фиксированное значение - это то, на что вам следует обратить внимание. Понимание сути этих значений свойства дает вам прочную основу макета на основе CSS, ограниченную только вашим воображением. Надеюсь, ваши дни угадывания значений позиций в безумном исправлении ошибок в последнюю минуту прошли.

Общие сведения о методах позиционирования CSS - Учебное пособие

Свойство position определяет, как элемент будет располагаться на странице.

Методы позиционирования CSS

Правильное размещение элементов на веб-страницах необходимо для хорошего дизайна макета.В CSS есть несколько методов, которые вы можете использовать для позиционирования элементов. В следующем разделе описаны эти методы позиционирования один за другим.

Статическое позиционирование

Статически позиционируемый элемент всегда позиционируется в соответствии с обычным потоком страницы. Элементы HTML по умолчанию позиционируются статично. На статически позиционированные элементы не влияют свойства top , bottom , left , right и z-index .

  .box {
    отступ: 20 пикселей;
    фон: # 7dc765;
}  

Относительное позиционирование

Элемент с относительным позиционированием располагается относительно своего нормального положения.

В схеме относительного позиционирования положение бокса элемента вычисляется согласно нормальному потоку.Затем коробка сдвигается из этого нормального положения в соответствии со свойствами - вверху или внизу и / или влево или вправо .

  .box {
    положение: относительное;
    слева: 100 пикселей;
}  

Примечание: Относительно позиционированный элемент может перемещаться и перекрывать другие элементы, но он сохраняет пространство, изначально зарезервированное для него в нормальном потоке.


Абсолютное позиционирование

Абсолютно позиционированный элемент позиционируется относительно первого родительского элемента, положение которого отличается от статического. Если такой элемент не найден, он будет расположен на странице относительно левого верхнего угла окна браузера. Смещения блока дополнительно можно указать с помощью одного или нескольких свойств: верхний , правый , нижний и левый .

Абсолютно позиционированные элементы полностью выводятся из нормального потока и, таким образом, не занимают места при размещении родственных элементов. Однако он может перекрывать другие элементы в зависимости от значения свойства z-index . Кроме того, абсолютно позиционированный элемент может иметь поля, и они не сворачиваются с другими полями.

  . box {
    позиция: абсолютная;
    верх: 200 пикселей;
    слева: 100 пикселей;
}  

Фиксированное позиционирование

Фиксированное позиционирование - это подкатегория абсолютного позиционирования.

Единственное отличие состоит в том, что элемент с фиксированным позиционированием фиксируется относительно области просмотра браузера и не перемещается при прокрутке.

  .box {
    положение: фиксированное;
    верх: 200 пикселей;
    слева: 100 пикселей;
}  

Примечание: В случае типа носителя для печати фиксированный позиционированный элемент отображается на каждой странице и фиксируется по отношению к страничному блоку (даже при предварительном просмотре печати). IE7 и IE8 поддерживают фиксированное значение, только если указано .

Учебное пособие по расширенному позиционированию

| HTML и CSS - это сложно

Абсолютное позиционирование

«Абсолютное позиционирование» аналогично относительному позиционированию, но смещение относится ко всему окну браузера, а не к исходному положение элемента.Поскольку больше нет отношений с статический поток страницы, считайте, что это самый ручной способ разметки элемент.

Давайте посмотрим, добавив в нашу таблицу стилей следующее правило:

  .item-absolute {
  позиция: абсолютная;
  верх: 10 пикселей;
  слева: 10 пикселей;
}
  

Наша структура HTML точно такая же, как и в предыдущем примере, но прикрепите фиолетовое изображение в верхнем левом углу окна браузера. Ты можешь также попробуйте установить значение снизу или справа , чтобы получить более четкое представление о том, что происходит.

Другой интересный эффект absolute заключается в том, что он полностью удаляет элемент из обычного потока страницы. Это легче увидеть с элементы, выровненные по левому краю, поэтому давайте временно изменим justify-content свойство в нашем правиле .example :

  .example {
  дисплей: гибкий;
  justify-content: гибкий старт;
  
}
  

В нашем примере относительного позиционирования (первая строка) все еще есть пространство, где раньше находился позиционируемый элемент, но с абсолютным позиционированием, это пространство исчезло.Это как если бы .item-absolute не существует даже для своих родительских и окружающих элементов. Быть уверенным измените justify-content обратно на space-about прежде чем двигаться дальше.

В большинстве случаев такое поведение не очень полезно, потому что оно будет означать все, что на вашей странице должно быть абсолютно позиционируется - иначе мы получим непредсказуемое перекрытие статических элементы с абсолютными элементами. Итак, почему абсолютный даже существует?

(относительно) Абсолютное позиционирование

Абсолютное позиционирование становится более практичным, когда оно выполняется относительно какой-то другой элемент, который - это в статическом потоке страницы.К счастью, есть способ изменить систему координат абсолютно позиционированный элемент.

Координаты абсолютных элементов всегда относительно ближайшего контейнер, который является позиционированным элементом. Он только возвращается к тому, чтобы относиться к браузер, когда ни один из его предков не позиционируется. Итак, если мы изменим .item-absolute родительский элемент должен быть относительно позиционирован, он должен появиться в верхнем левом углу , этот элемент вместо окно браузера.

  .absolute {
  положение: относительное;
}
  

Div .absolute размещается в обычном потоке страницы, и мы можем вручную перемещать наш .item-absolute , где бы мы ни нужно. Это замечательно, потому что если мы хотим изменить нормальный поток контейнера, скажем, для мобильного макета, любые абсолютно позиционированные элементы будут автоматически двигаться вместе с ним.

Обратите внимание, что мы не указали координаты смещения для Абсолютный .Мы используем относительное позиционирование подошвы чтобы позволить нашему абсолютному элементу вернуться в нормальный поток страница. Вот как мы безопасно комбинируем абсолютное позиционирование со статическим позиционирование.

Детальное позиционирование - научитесь кодировать расширенный HTML и CSS

Урок 2

В этом уроке 2
CSS
Поделиться

Когда дело доходит до создания макетов и размещения контента на странице, существует несколько различных методов. Какой метод использовать, во многом зависит от содержания и целей страницы, поскольку одни методы могут быть лучше других.

Например, возможность размещать элементы рядом друг с другом обеспечивает приятный, чистый макет, восприимчивый к различным элементам на странице. Однако, когда требуется более строгий контроль, элементы могут быть расположены с использованием других методов, включая относительное или абсолютное позиционирование.

В этом уроке мы начнем с того, что посмотрим, как содержать числа с плавающей запятой.После этого мы рассмотрим более подробные методы позиционирования, в том числе о том, как точно позиционировать элементы как по оси x , так и по оси y , а также по оси z .

Содержит поплавки

Плавающие элементы - это естественный процесс при создании макета веб-сайта и инстинктивный метод позиционирования элементов на странице. Плавающие элементы позволяют элементам располагаться рядом или отдельно друг от друга. Они обеспечивают возможность создания естественного потока в макете и позволяют элементам взаимодействовать друг с другом в зависимости от их размера и размера их родительского элемента.

При перемещении положение элемента зависит от других элементов, расположенных вокруг него. Будет ли этот элемент встречаться с соседним? Он появится на новой строке? Все это зависит от DOM (объектной модели документа) и того, что окружает элемент.

Что такое DOM?

DOM, или объектная модель документа, представляет собой API для документов HTML и XML, который обеспечивает их структурное представление. В нашем случае мы говорим конкретно о HTML-документах, поэтому DOM представляет все различные элементы и их отношения друг к другу.

Представление можно рассматривать как своего рода дерево, в котором каждый элемент имеет разные отношения с окружающими его элементами. Элементы, вложенные внутри других, имеют родственные и дочерние отношения, в то время как элементы, которые имеют одного и того же родителя, имеют родственные отношения.

Хотя поплавки и обеспечивают небольшую огневую мощь, у них есть свои проблемы. Самая популярная проблема связана с родительским элементом, который содержит множество плавающих элементов. Контент на странице будет соответствовать размеру и размещению плавающего дочернего элемента, но эти плавающие элементы больше не влияют на внешние края родительского контейнера.В этом случае родительский элемент теряет контекст того, что он содержит, и сворачивается, тем самым давая родительскому элементу высоту , равную 0 , и игнорируя различные другие свойства. Часто это может остаться незамеченным, особенно когда родительский элемент не имеет привязанных к нему стилей, а вложенные элементы выглядят правильно выровненными.

Если вложенные элементы не совпадают правильно, могут появиться ошибки стиля. Взглянув на демонстрацию ниже, .раздел box-set должен иметь светло-серый фон, однако фон не виден, так как все элементы, вложенные в него, являются плавающими. Осмотрев раздел .box-set , вы увидите, что высота составляет 0 .

HTML
  
 1
2
3
4
5
6 
 
Вставка 1
Вставка 2
Вставка 3
CSS
  
 1
2
3
4
5
6
7
8
9
10 
.box-set {
  фон: #eaeaed;
}
.box {
  фон: # 2db34a;
  плыть налево;
  маржа: 1.858736059%;
  ширина: 29,615861214%;
}
 

Одним из способов принудительного включения этих чисел с плавающей запятой является размещение пустого элемента непосредственно перед закрывающим тегом родительских элементов, в который необходимо включить объявление стиля clear: both; . Подобная очистка поплавков работает и в большинстве случаев допустима, но не совсем семантическая. В зависимости от того, сколько разных плавающих элементов необходимо очистить на странице, количество пустых элементов может начать быстро накапливаться, не обеспечивая при этом никакого реального контекстного значения для страницы.

К счастью, есть несколько различных техник, которые мы можем использовать для сдерживания этих поплавков, самые популярные из которых включают метод переполнения и метод clearfix.

Техника переполнения

Один из методов для содержания числа с плавающей запятой в родительском элементе - использовать свойство CSS overflow . Установка значения свойства overflow на auto в родительском элементе будет содержать числа с плавающей запятой, что приведет к фактической высоте для родительского элемента, включая серый фон в нашем примере.

Чтобы это работало в Internet Explorer 6, для родительского элемента требуется высота или ширина . Поскольку высота , , вероятно, может быть переменной, ширина , , 100%, подойдет. Использование overflow: auto; в Internet Explorer на компьютере Apple также добавит полосы прокрутки к родительскому элементу, в котором лучше использовать overflow: hidden; Декларация .

  
 1
2
3
4 
.box-set {
  перелив: авто;
}
 

Использование метода переполнения имеет ряд недостатков. Например, при добавлении стилей или перемещении вложенных элементов, которые выходят за пределы родительского, например, при попытке реализовать тени блоков и раскрывающиеся меню. В демонстрации ниже вы можете увидеть, как тень блока обрезается везде, где она находится за пределами родительского элемента. Кроме того, второй прямоугольник обрезается за пределами родительского элемента.

Различные браузеры по-разному обрабатывают свойство overflow и, следовательно, также могут реализовывать полосы прокрутки по-разному.Посмотрите на приведенный ниже пример в разных браузерах и обратите внимание, как столбцы отображаются по-разному в каждом браузере.

Техника Clearfix

В зависимости от контекста плавающих элементов лучшим методом для содержания плавающих элементов может быть метод clearfix. Метод clearfix немного сложнее, но имеет лучшую поддержку по сравнению с методом переполнения.

Метод clearfix основан на использовании псевдоэлементов : before и : after в родительском элементе.Используя эти псевдоэлементы, мы можем создавать скрытые элементы выше и ниже родительского элемента, содержащего поплавки. Псевдоэлемент : before используется для предотвращения сжатия верхнего поля дочерних элементов путем создания анонимного элемента table-cell с использованием display: table; Декларация . Это также помогает обеспечить согласованность в Internet Explorer 6 и 7. Псевдоэлемент : after используется для предотвращения сжатия нижнего поля дочерних элементов, а также для очистки вложенных плавающих элементов.

Добавление свойства * zoom к родительскому элементу запускает механизм hasLayout специально в Internet Explorer 6 и 7, который определяет, как элементы должны рисовать и связывать свое содержимое, а также как элементы должны взаимодействовать с другими элементами и соотноситься с ними. .

Взяв тот же пример, приведенный выше, вы можете увидеть, как содержатся поплавки, и что элементы могут существовать вне родительского элемента.

  
 1
2
3
4
5
6
7
8
9
10
11
12 
.бокс-сет: до,
.box-set: after {
  содержание: "";
  дисплей: таблица;
}
.box-set: after {
  ясно: оба;
}
.box-set {
  * масштабирование: 1;
}
 

Эффективно содержащие поплавки

Какие методы использовать, зависит от имеющегося контента и ваших личных предпочтений. Некоторые люди предпочитают строго придерживаться техники clearfix, поскольку она одинакова во всех отношениях. Другие считают, что в некоторых случаях метод clearfix - это слишком много кода, и предпочитают сочетание методов, основанных на содержании.Что вы решите использовать, зависит от вас, просто убедитесь, что он хорошо задокументирован и легко идентифицируется в любом случае.

Одна из распространенных практик - назначить класс родительскому элементу, который включает в себя поплавки, которые необходимо содержать. Например, используя технику clearfix, Дэн Седерхольм помог создать имя класса group . Затем имя класса group можно применить к любому родительскому элементу, который должен содержать числа с плавающей запятой.

  
 1
2
3
4
5
6
7
8
9
10
11
12 
.группа: до,
.group: after {
  содержание: "";
  дисплей: таблица;
}
.group: after {
  ясно: оба;
}
.group {
  * масштабирование: 1;
}
 
Отдельные псевдоэлементы

Стоит отметить только один псевдоэлемент : до и один : после для каждого элемента на данный момент. При попытке использовать технику clearfix с другим псевдоэлементным содержимым : до и : после вы можете не достичь желаемого результата.

В приведенных выше примерах стили clearfix не будут жить в классе box-set . Вместо этого к родительскому элементу, содержащему поплавки, необходимо добавить класс группы .

Свойство позиции

Иногда вам нужно больше контроля над положением элемента, больше, чем может предоставить float, и в этом случае в игру вступает свойство position . Свойство position принимает пять различных значений, каждое из которых обеспечивает разные способы уникального позиционирования элемента.

Статическое положение

Элементы по умолчанию имеют позицию , , значение статическое , то есть они не имеют и не будут принимать никаких конкретных свойств смещения блока. Кроме того, элементы будут расположены так, как задумано, с их поведением по умолчанию.

В демонстрации ниже все коробки уложены друг на друга, поскольку они являются элементами уровня блока и не перемещаются в каком-либо определенном направлении.

HTML
  
 1
2
3
4
5
6
7 
 
Вставка 1
Вставка 2
Вставка 3
Вставка 4
CSS
  
 1
2
3
4
5
6
7
8
9 
. box-set {
  фон: #eaeaed;
}
.box {
  фон: # 2db34a;
  высота: 80 пикселей;
  ширина: 80 пикселей;
}
 

Относительное положение

Относительное значение для свойства position очень похоже на значение static . Основное отличие состоит в том, что относительное значение принимает свойства смещения блока вверху , справа , внизу и слева .Эти свойства смещения бокса позволяют точно позиционировать элемент, сдвигая элемент из положения по умолчанию в любом направлении.

Как работают свойства смещения бокса

Свойства смещения блока: сверху , справа , снизу и слева , определяют, как элементы могут быть расположены и в каком направлении. Эти свойства смещения работают только с элементами с относительным значением позиционирования , абсолютным или фиксированным значением .

Для относительно позиционированных элементов эти свойства определяют, как элемент должен быть перемещен из положения по умолчанию. Например, использование значения top , равного 20px, на относительно расположенном элементе, подтолкнет элемент на 20 пикселей вниз от того места, где он был первоначально размещен. Изменение значения top на -20px вместо этого потянет элемент на 20 пикселей вверх от того места, где он был изначально размещен.

Для элементов, использующих абсолютное позиционирование или фиксированное , эти свойства определяют расстояние между элементом и краями его родительского элемента.Например, использование значения top 20px для абсолютно позиционированного элемента подтолкнет элемент на 20 пикселей вниз от верха его относительно позиционированного родителя. Переключение значения top на -20px затем потянет элемент на 20 пикселей вверх от верха его относительно позиционированного родителя.

В то время как относительная позиция принимает свойства смещения блока, элемент по-прежнему остается в нормальном или статическом потоке страницы.В этом случае другие элементы не будут мешать тому, где изначально был размещен относительно позиционированный элемент. Кроме того, относительно позиционированный элемент может перекрывать или перекрывать другие элементы, не перемещая их из положения по умолчанию.

В демонстрации ниже вы заметите, что элементы по-прежнему наложены друг на друга, однако они смещены от своих позиций по умолчанию в соответствии с их индивидуальными значениями свойств смещения блока. Эти значения заставляют коробки перекрывать друг друга, но не толкают друг друга в разных направлениях.Когда элемент расположен относительно, окружающие элементы будут соблюдать положение относительно позиционированных элементов по умолчанию.

HTML
  
 1
2
3
4
5
6
7 
 
Вставка 1
Вставка 2
Вставка 3
Вставка 4
CSS
  
 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20 
. box-set {
  фон: #eaeaed;
}
.box {
  фон: # 2db34a;
  высота: 80 пикселей;
  положение: относительное;
  ширина: 80 пикселей;
}
.box-1 {
  верх: 20 пикселей;
}
.box-2 {
  слева: 40 пикселей;
}
.box-3 {
  внизу: -10px;
  вправо: 20 пикселей;
}
 

В случае, если свойства смещения блока верхний и нижний оба объявлены для относительно позиционированного элемента, свойства верхний будут иметь приоритет. Кроме того, если свойства смещения поля слева и справа объявлены для относительно позиционированного элемента, приоритет дается тому направлению, в котором написан язык страницы.Например, на английских страницах свойство смещения влево, имеет приоритет, а для арабских страниц свойство смещения вправо, имеет приоритет.

Абсолютное положение

Абсолютно позиционированные элементы принимают свойства смещения блока, однако они удаляются из обычного потока документа. После удаления элемента из нормального потока элементы позиционируются непосредственно относительно содержащего их родителя, который позиционируется относительно или абсолютно.Если относительно или абсолютно позиционированный родительский элемент отсутствует, абсолютно позиционированный элемент будет позиционирован относительно тела страницы.

Использование абсолютно позиционированных элементов и указание свойств вертикального и горизонтального смещения перемещает элемент с этими значениями свойств относительно его относительно позиционированного родителя. Например, элемент со значением top , равным 50px, и значением справа , равным 100px , будет располагать элемент на 50 пикселей вниз от верха его относительно позиционированного родителя и на 100 пикселей справа от его относительного позиционированный родитель.

Кроме того, использование абсолютно позиционированного элемента и не указание какого-либо свойства смещения блока позиционирует элемент в верхнем левом углу его ближайшего относительно позиционированного родителя. Установка одного свойства смещения бокса, например top , будет позиционировать элемент абсолютно по вертикали, но оставит горизонтальное позиционирование равным значению по умолчанию flush left.

На демонстрации ниже вы можете увидеть, как каждый блок позиционируется абсолютно по отношению к родительскому разделу, относительно которого позиционируется.Каждый отдельный ящик перемещается с определенной стороны с положительным значением или вынимается с определенной стороны с отрицательным значением.

HTML
  
 1
2
3
4
5
6
7 
 
Вставка 1
Вставка 2
Вставка 3
Вставка 4
CSS
  
 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21 год
22
23
24
25
26
27 
.box-set {
  фон: #eaeaed;
  высота: 200 пикселей;
  положение: относительное;
}
. box {
  фон: # 2db34a;
  высота: 80 пикселей;
  позиция: абсолютная;
  ширина: 80 пикселей;
}
.box-1 {
  верх: 6%;
  осталось: 2%;
}
.box-2 {
  верх: 0;
  вправо: -40 пикселей;
}
.box-3 {
  внизу: -10px;
  вправо: 20 пикселей;
}
.box-4 {
  внизу: 0;
}
 

Когда элемент имеет фиксированную высоту и ширину и абсолютно позиционирован, свойство top имеет приоритет, если объявлены свойства смещения top и bottom .Как и в случае относительно позиционированных элементов, если элемент с фиксированной шириной имеет свойства смещения поля слева и справа , приоритет отдается направлению, в котором написан язык страницы.

Если элемент не имеет определенной высоты или ширины и абсолютно позиционирован, при использовании комбинации свойств смещения поля верхний и нижний отображается элемент с высотой, охватывающей весь указанный размер. То же самое касается использования свойств смещения поля слева и справа , в результате получается элемент с полной шириной на основе свойств смещения поля слева и справа . Использование всех четырех свойств смещения блока отобразит элемент с полной указанной высотой и шириной.

Фиксированное положение

Использование значения позиционирования фиксированное работает так же, как значение абсолютное , однако позиционирование выполняется относительно области просмотра браузера и не прокручивается вместе со страницей.При этом элементы всегда будут присутствовать независимо от того, где находится пользователь на странице. Единственная оговорка с фиксированным позиционированием заключается в том, что он не работает с Internet Explorer 6. Если вы хотите принудительно установить фиксированное позиционирование в Internet Explorer 6, есть подходящие уловки.

Использование нескольких свойств смещения блока с фиксированным позиционированием приведет к тому же поведению, что и абсолютно позиционированный элемент.

Сохраняя те же свойства смещения блока, что и в предыдущей демонстрации, посмотрите, как блоки позиционируются относительно области просмотра браузера, а не содержащего, относительно позиционированного родителя.

HTML
  
 1
2
3
4
5
6
7 
 
Вставка 1
Вставка 2
Вставка 3
Вставка 4
CSS
  
 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21 год
22 
 .box {
  фон: # 2db34a;
  высота: 80 пикселей;
  положение: фиксированное;
  ширина: 80 пикселей;
}
.box-1 {
  верх: 6%;
  осталось: 2%;
}
.box-2 {
  верх: 0;
  вправо: -40 пикселей;
}
. box-3 {
  внизу: -10px;
  вправо: 20 пикселей;
}
.box-4 {
  внизу: 0;
}
 
Фиксированный верхний или нижний колонтитул

Одно из наиболее распространенных применений фиксированного позиционирования - создание фиксированного верхнего или нижнего колонтитула, привязанного к одной стороне страницы. Когда пользователь прокручивает элемент, он остается преобладающим, всегда в пределах области просмотра, чтобы пользователи могли взаимодействовать с ним.

В приведенном ниже коде и демонстрации показано, как этого можно достичь.Обратите внимание, как объявлены свойства смещения поля слева и справа . Это позволяет нижнему колонтитулу охватывать всю ширину нижней части страницы, и это делает это без нарушения блочной модели, позволяя свободно применять поля, границы и отступы.

HTML
  
 1
2 
 
Фиксированный нижний колонтитул
CSS
  
 1
2
3
4
5
6
7
8
9
10
11 
 корпус {
  фон: #eaeaed;
}
нижний колонтитул {
  фон: # 2db34a;
  внизу: 0;
  слева: 0;
  положение: фиксированное;
  справа: 0;
}
 

Свойство индекса Z

По своей природе веб-страницы часто считаются двухмерными, отображая элементы по оси x и y . Однако, когда вы начинаете позиционировать элементы, они иногда кладутся друг на друга. Чтобы изменить порядок расположения этих элементов, также известный как ось z, необходимо использовать свойство z-index .

Как правило, элементы располагаются на оси z так, как они появляются в модели DOM. Элементы, идущие вверху модели DOM, располагаются позади элементов, следующих за ними. Изменить это наложение с помощью свойства z-index довольно просто.Элемент с наибольшим значением z-index будет отображаться вверху независимо от его размещения в DOM.

Чтобы применить свойство z-index к элементу, необходимо сначала применить значение position , равное относительно , абсолютному или фиксированному . Так же, как если бы вы применили какие-либо свойства смещения блока.

В приведенном ниже примере без свойства z-index каждый блок будет позиционирован точно, начиная с блока два, расположенного наверху блока один, затем блока три, расположенного поверх блока два, и так далее. При изменении порядка наложения с помощью свойства z-index прямоугольник два теперь размещается над каждым другим прямоугольником, за ним следует третий прямоугольник под ним, а четвертый прямоугольник - под третьим.

HTML
  
 1
2
3
4
5
6
7 
 
Вставка 1
Вставка 2
Вставка 3
Вставка 4
CSS
  
 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21 год
22
23
24
25
26
27
28
29
30 
.box-set {
  фон: #eaeaed;
  высота: 160 пикселей;
  положение: относительное;
}
.box {
  фон: # 2db34a;
  граница: 2px solid # ff7b29;
  позиция: абсолютная;
}
.box-1 {
  слева: 10 пикселей;
  верх: 10 пикселей;
}
.box-2 {
  внизу: 10 пикселей;
  слева: 70 пикселей;
  z-индекс: 3;
}
.box-3 {
  слева: 130 пикселей;
  верх: 10 пикселей;
  z-индекс: 2;
}
. box-4 {
  внизу: 10 пикселей;
  слева: 190 пикселей;
  z-индекс: 1;
}
 

Ресурсы и Ссылки

Понимание позиции в CSS. Развитие понимания… | Джейкоб Гринуэй

Существует два типа позиционирования

Есть позиционирование статического типа и позиционирование относительного типа .

Статическое позиционирование состоит только из одного значения: position: static . Это значение по умолчанию, поэтому вы редко увидите его объявленным.

Позиционирование относительного типа состоит из значений позиция: относительная , позиция : абсолютная и позиция : фиксированная . Эти значения позиционирования взаимодействуют друг с другом и позволяют вам перемещать элементы интересными способами.

Статическое позиционирование

Давайте сначала избавимся от скучных вещей. Хотя не очень часто вы увидите объявление статической позиции в природе, нам следует начать наше путешествие по позиционированию с самого начала.

 .ourBox {
положение: статическое;
}
Статическое позиционирование, по умолчанию для всех элементов.

Статическое позиционирование - это позиционирование по умолчанию для каждого элемента, независимо от того, объявляете ли вы его. Он указывает элементу позиционировать себя в обычном потоке документа, как небольшую коробку.

Относительное позиционирование (условно говоря)

Относительное позиционирование - вот где все становится интересно.

Доступные значения: относительный , абсолютный и фиксированный , и они называются позициями относительного типа, потому что они позволяют элементам смещаться на относительно на самих себя, родителя или окна просмотра соответственно.

Все позиции относительного типа могут выполнять следующее:

  • Перемещаться из нормальных положений потока за счет использования свойств смещения , , а именно: сверху, справа, снизу и слева.
  • Создайте новый контекст позиционирования относительного типа , который позволяет дочерним элементам с position: absolute располагаться относительно относительно положения этого элемента .

Давайте подробнее рассмотрим каждую из трех позиций относительного типа.

Относительная позиция

Вы, наверное, видели это раньше. Код выглядит так:

 .ourBox {
position: relative;
}

Элементы, которые находятся в положении : относительный , могут быть перемещены из своего нормального положения потока, при этом занимая то же пространство.Это достигается за счет использования этих свойств смещения для смещения элемента относительно самого себя .

Для ясности, когда вы используете смещение для визуального перемещения элемента с положением : относительно , пространство, которое он занимает в документе, не перемещается.

Давайте посмотрим на пример.

 .ourBox {
позиция: относительная; верх: 20 пикселей;
слева: 20 пикселей;
}
Наш блок смещен относительно исходного положения с использованием свойств смещения.

Здесь мы видим, что верх элемента смещен на 20 пикселей, относительно того места, где он был бы в нормальном потоке . То же самое и с левой стороны.

Обратите внимание, что положение полей с обеих сторон не изменилось. Помните, что когда вы смещаете позицию элемента на position: relative , пространство, которое он занимает, не перемещается, поэтому это не повлияет ни на что вокруг.

Это похоже на то, что наша коробка свободна и может идти куда угодно, но всегда относительно того, где она была изначально.

Важно отметить, что если вы применяете позиция: относительно к элементу, вам не нужно применять свойства смещения. Некоторые коробки в конце концов хороши там, где они есть.

Position Absolute

Strap in.

position: absolute по существу делает то же самое, что и позиция : относительная , с двумя ключевыми отличиями:

  • Элемент выводится из нормального потока и выходит из нет место за .
  • Элемент позиционируется относительно своего ближайшего родительского элемента с позиционированием относительного типа.

Давайте посмотрим:

 .ourBoxesParent {
position: relative;
} .ourBox {
позиция: абсолютная;
верх: 0;
осталось: 0;
}
Здесь мы выводим наш блок из нормального потока и смещаем его относительно ближайшего родителя относительного типа.

Мы добавили обертку к нашему трио коробок, которая имеет положение : относительно .Мы также изменили поле на : абсолютное значение . Обратите внимание, что пространство, которое мы занимали раньше, рухнуло - теперь два серых прямоугольника появляются рядом.

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *