Смещение css. Позиционирование CSS
Позиционирование — одно из ключевых понятий в блочной верстке. Разобравшись с ним, вам многое станет понятно, а верстка из шаманства превратится в осмысленный процесс. Итак, речь в статье пойдет о CSS-свойствах position и float .
1. position: static
По умолчанию все элементы на странице имеют статическое позиционирование (position: static), это означает, что элемент не позиционирован, и появляется в документе на своем обычном месте, то есть в том же порядке, как и в html-разметке.
Нет необходимости специально назначать это свойство какому-либо элементу, если только вам не требуется изменить ранее установленное позиционирование на дефолтное.
#content{ position: static; }
2. position:relative
Относительное позиционирование (position: relative) позволяет вам использовать свойства: top, bottom, left и right, для расположения элемента относительно того места, где бы он появился при обычном позиционировании.
Давайте переместим #content на 20 пикселей вниз, и на 40 пикселей влево:
#content{ position: relative; top: 20px; left: -40px; }
Обратите внимание, что на том месте, где бы должен был находится наш блок #content, теперь образовалось пустое пространство. Следующий за блоком #content, блок #footer не переместился ниже, потому что, #content по-прежнему занимает свое место в документе, несмотря на то, что мы передвинули его.
На данном этапе может показаться, что относительное позиционирование не так уж и полезно, но, не спешите с выводами, далее в статье, вы узнаете, для чего его можно использовать.
3. position: absolute
При абсолютном позиционировании (position: absolute), элемент удаляется из документа, и появляется там, где вы ему скажете.
Давайте, для примера, переместим блок #div-1a в верхний, правый угол страницы:
#div-1a { position:absolute; top:0; right:0; width:200px; }
Обратите внимание, что на этот раз, поскольку блок #div-1a был удален из документа, оставшиеся элементы на странице расположились по-другому: #div-1b, #div-1c и #footer переместились выше, на место удаленного блока. А сам блок #div-1a, расположился точно в правом, верхнему углу страницы.
Таким образом, мы можем позиционировать любой элемент относительно страницы, однако этого не достаточно. На самом деле, нам необходимо позиционировать #div-1a относительно родительского блока #content. И на этом этапе, относительное позиционирование вновь вступает в игру.
4. position: fixed
Фиксированное позиционирование (position: fixed), является подразделом абсолютного позиционирования. Единственное его отличие в том, что он всегда находится в видимой области экрана, и не двигается во время прокрутки страницы. В этом отношении, он немного похож на фиксированное фоновое изображение.
#div-1a { position:fixed; top:0; right:0; width:200px; }
В IE с position: fixed не все так гладко, как бы нам хотелось, но существует множество способов обойти эти ограничения.
5. position:relative + position:absolute
Назначив блоку #content относительное позиционирование (position: relative), мы сможем позиционировать любые дочерние элементы, относительно его границ. Давайте разместим блок #div-1a, в верхнем правом углу блока #content.
#content { position:relative; } #div-1a { position:absolute; top:0; right:0; width:200px; }
6. Две колонки
Вооружившись знаниями из предыдущих шагов, можно попробовать сделать две колонки, с помощью относительного и абсолютного позиционирования.
#content { position:relative; } #div-1a { position:absolute; top:0; right:0; width:200px; } #div-1b { position:absolute; top:0; left:0; width:200px; }
Одним из преимуществ абсолютного позиционирования, является возможность размещать элементы в произвольном порядке, независимо от того, как именно они расположены в разметке. В приведенном выше примере, блок #div-1b расположен перед блоком #div-1a.
А сейчас у вас должен был возникнуть вопрос: “А куда же делись остальные элементы из нашего примера?”. Они скрылись под абсолютно расположенными блоками. К счастью, есть возможность это исправить.
7. Две колонки с фиксированной высотой
Одно из решений – задать фиксированную высоту контейнеру, содержащему колонки.
#content { position:relative; height: 450px; } #div-1a { position:absolute; top:0; right:0; width:200px; } #div-1b { position:absolute; top:0; left:0; width:200px; }
Решение не очень подходящее, поскольку мы никогда не знаем заранее, какого размера текст, будет расположен в колонках, и какой шрифт будет использован.
8. Float
Для колонок с переменной высотой, абсолютное позиционирование не подходит, поэтому давайте рассмотрим другой вариант.
Назначив блоку float, мы максимально возможно оттолкнем его к правому (или левому) краю, а следующий за блоком текст, будет обтекать его. Обычно такой прием используется для картинок, но мы будем использовать его для более сложной задачи, поскольку это единственный инструмент, имеющийся в нашем распоряжении.
#div-1a { float:left; width:200px; }
9. “Плавающие” колонки
Если назначить первому блоку float: left, а затем второму float: left, каждый из блоков прижмется к левому краю, и мы получим две колонки, с переменной высотой.
#div-1a { float:left; width:150px; } #div-1b { float:left; width:150px; }
Также, можно назначить колонкам противоположное значение float, в этом случае, они распределятся по краям контейнера.
#div-1a { float:right; width:150px; } #div-1b { float:left; width:150px; }
Но теперь у нас появилась другая проблема – колонки выходят за пределы родительского контейнера, тем самым ломая всю верстку. Эта самая распространенная проблема начинающих верстальщиков, хотя решается она довольно просто.
10. Очистка float
Чистку флоатов можно делать двумя способами. Если после колонок идет еще один блок, достаточно назначить ему clear: both.
#div-1a { float:left; width:190px; } #div-1b { float:left; width:190px; } #div-1c { clear:both; }
Или же назначить родительскому контейнеру свойство overflow: hidden
#content { overflow:hidden; }
В любом случае, результат будет один и тот же.
Заключение
Сегодня были рассмотрены только базовые приемы позиционирования, и самые простые примеры. Также, в помощь начинающим верстальщикам я всегда рекомендую цикл статей Ивана Сагалаева, которые в свое время мне очень помогли.
Выше мы говорили о том, что позиционировать элементы страницы можно путем использования таблиц. Но это же можно делать и с помощью стилей. Среди параметров стиля имеются специальные свойства для позиционирования:
- left - для задания расстояния в пикселах от левого края окна (х-координата);
- top - для задания расстояния в пикселах от верхнего края окна (у-координата);
- z-index - для указания порядка, в котором элементы будут перекрывать друг друга; это новое измерение, элементы с большим z-индексом будут появляться над элементами с меньшим z-индексом.
Конечно, при использовании этих трех свойств не создается эффект трехмерного
пространства, но это уже нечто большее, чем плоская поверхность. В этом
случае говорят о 2,5-мерном пространстве.
Кроме свойств-координат, нам понадобится свойство роsition
,
которое в сочетании со свойствами left
и
top
позволяет устанавливать элементы в определенные
позиции окна. Свойство position может принимать три значения:
- absolute - заданные свойства left и top поставят элемент в точку с координатами х и у относительно верхнего левого угла контейнера (объекта, содержащего данный элемент). Если они определены для элемента вне контейнера, то началом отсчета координат будет верхний левый угол страницы. Заметим, что положение элемента не зависит от положения его тега внутри HTML-документа;
- relative - элемент будет установлен в соответствии с тем, в каком месте исходного текста он находится; это значение установлено по умолчанию. Например, если элемент находится в трех строках от начала его выделения в тексте документа, то по умолчанию считается, что свойство позиционирования имеет значение relative , а свойства координат left и top - нулевые значения. Ненулевые значения свойств left и top задают сдвиг элемента относительно исходного положения;
- static - элемент будет поставлен в некоторое положение относительно фона и не будет перемещаться при прокручивании страницы.
Следующий пример показывает использование свойства z-index . Хотя в тексте программы картинка описана выше остальных элементов, за счет присвоения ей индекса с большим номером происходит перемещение ее поверх первого текста. Таким образом, использование свойства z-index освобождает от пут естественного порядка упоминания элементов в тексте HTML-программы.
Рис. 666. Использование
свойства i-index позволяет изменить естественный порядок следования элементов
в тексте HTML-документа
При позиционировании элементов может оказаться, что размеры элемента превосходят
размеры фрагмента (отводимой области, заданной в нашем примере тегом В следующем примере используется свойство overflow
для создания механизма
прокрутки первого текста. Рис. 667. Механизм прокрутки текста,
реализованный с помощью свойства overflow
Конечно, неказистые страницы с предыдущих рисунков создавались лишь
с целью продемонстрировать возможности языка по позиционированию элементов.
Вы сами решите, какие средства и для чего будете использовать на своей
Web-странице. С помощью свойств позиционирования нетрудно создавать для надписей эффект
трехмерности. Идея состоит в том, чтобы вывести одинаковые по содержанию
тексты слегка сдвинутыми друг относительно друга и окрашенными в различные
цвета. Попробуйте в качестве упражнения написать соответствующую программу.
На рисунке показано примерно то, что должно получиться. Ниже рисунка приведен
один из возможных вариантов программы, которая создает «трехмерную» надпись. Рис. 668. Пример создания трехмерного
текста с помощью CSS
Объемный текст"Р> Oбъeмный
текстР> Объемный текст Р> Обратите внимание, что этот способ создания эффектных заголовков значительно
экономнее, чем использование графических файлов с аналогичным содержанием. В наши дни веб-разработчики могут строить сложные раскладки веб-страниц, используя различные техники CSS. Некоторые из этих техник имеют длинную историю (флоаты), другие (флексбокс) достигли популярности в последние годы. В этой статье мы внимательно рассмотрим некоторые малоизвестные вещи, касающиеся CSS-позиционирования . Перед тем как начать, давайте кратко вспомним основы различных типов позиционирования. Свойство CSS position определяет тип позиционирования элемента. static это значение свойства позиционирования по умолчанию. Мы сообщаем, что этот элемент не использует позиционирование - позиционирование применяется, только если задать тип позиционирования, отличный от дефолтного. Для этого надо свойству position задать одно из следующих значений: И только после задания позиционирования, можно использовать свойства, смещающие элемент: Надо учитывать, что если у элемента задано свойство position в значении absolute или fixed , то он является абсолютно позиционированным элементом. Также у позиционированных элементов начинает работать свойство z-index , определяющее порядок наложения. Теперь быстро рассмотрим три базовых различия между доступными типами позиционирования: Подробнее это можно рассмотреть в демо: Примечание: позиционирование “приклеенных элементов” до сих пор является экспериментальной технологией с ограниченной поддержкой в браузерах . Конечно, при желании вы можете использовать полифилл , чтобы добавить этот функционал в браузер, но с учетом малой распространенности это свойство в статье обсуждаться не будет. Я уверен, что большинство знает принцип работы абсолютного позиционирования. Однако новичков многое в нем может смутить. Поэтому я решил начать с него при описании малоизвестные особенностей позиционирования. Итак, абсолютно позиционированный элемент смещается относительно своего ближайшего спозиционированного предка. Конечно, это работает, если у кого-либо из предков position отличается от static - если у элемента нет спозиционированных предков, он смещается относительно зоны видимости. Это демонстрируется следующим примером: В этом демо зеленый блок изначально спозиционирован абсолютно с нулевыми отступами bottom:0 и left:0 , его предку (красному блоку) позиционирование не задавалось вообще. Однако, мы относительно позиционировали внешнюю обертку (элемент с классом jumbotron). Отметьте, как меняется позиционирование зеленого блока при изменении типа позиционирования его предков. Если мы применим к плавающему элементу абсолютное или фиксированное позиционирование, свойство float получит значение none . С другой стороны, если мы зададим относительное позиционирование, элемент останется плавающим. Взгляните на соответствующее демо: В этом примере, мы определяем два разных элемента, уплывающих вправо. Отметьте, что когда красный блок становится абсолютно позиционированным, он игнорирует значение свойства float , в то время как относительно спозиционированный зеленый блок сохраняет значение float . Строчный элемент с абсолютным или фиксированным позиционированием приобретает свойства блочного элемента. Подробнее конвертация строчных элементов в блочные описана в таблице . В данном случае мы создали два разных элемента. Первый (зеленый блок) это блочный элемент, а второй (красный блок) - строчный. Изначально виден только зеленый блок. Красный блок не виден потому, что заданные ему свойства width и height работают только с блочными и строчно-блочными элементами, а так как в нем нет контента, у него нет никаких размеров. При задании красному блоку абсолютного или фиксированного позиционирования, он становится блочным и заданные в нем размеры блока начинают действовать. По умолчанию, когда у два вертикальных внешних отступа соприкасаются, они объединяются в один, равный максимальному из них. Это называется схлопывание внешних отступов . Поведение абсолютно позиционированных элементов здесь схоже с плавающими элементами - их отступы не объединяются с соседними. В этом демо элементу задан отступ в 20 пикселей. Его отступ коллапсирует с отступом родительского элемента, также равного 20 пикселям. Как видите, только при абсолютном позиционировании схлопывания не происходит. Но как мы можем предотвратить схлопывание отступов? Нам нужно поместить между ними какой-либо разделитель. Это может быть внутренний отступ (padding) или граница (border), их можно применять как к родительскому, так и к дочернему элементу. Другой вариант - добавить клирфикс к родительскому элементу. Использовали ли вы когда-либо проценты вместо пикселей для позиционирования элементов? Если ответ да, то вы знаете, что смещение элемента зависит от выбранных единиц исчисления (пикселей или процентов). Это немного смущает, правда? Итак, сначала посмотрим, что говорит спецификация об смещении в процентах: Смещение в процентах от ширины (для left и right) или высоты (top или bottom) родительского блока. Для приклеенных элементов, смещение рассчитывается в процентах от ширины (для left и right) или высоты (top или bottom) потока. Допустимы отрицательные значения. Как было сказано, при задании смещения в процентах, позиция элемента зависит от ширины и высоты его родителя. Демо показывает эту разницу: В этом примере для смещения используются пиксели и проценты. Конечно, при задании смещения в пикселях элемент сдвигается туда, куда надо. А если мы выберем проценты для смещения, результат будет зависеть от размеров родительского элемента. Вот визуализация показывающая, как рассчитывается новая позиция: Примечание: как вы, наверное, знаете, свойство transform (вместе с различными функциями translate) также позволяет изменить позицию элемента. Но в этом случае при использовании процентов расчет будет происходить на основе размер самого элемента, а не его родителя. Я надеюсь, что эта статья помогла вам лучше понять позиционирование в CSS и разъяснила основные сложности. Одной из лучших сторон CSS является то, что стили дают нам возможность позиционировать содержимое и элементы на странице практически любым мыслимым образом. Это вносит структурность в наш дизайн и помогает сделать контент более наглядным. Есть несколько разных типов позиционирования в CSS, каждый из этих типов имеет свою область действия. В этой главе мы собираемся взглянуть на несколько различных случаев применения - создание многократно используемых макетов и уникальное позиционирование одноразовых элементов, а также описание нескольких методов как это сделать. Один из способов позиционирования элементов на странице - через свойство float
. Это свойство довольно универсально и может применяться разными путями. По существу, свойство float
берёт элемент, убирает его из обычного потока страницы и позиционирует слева или справа от родительского элемента. Все остальные элементы на странице будут обтекать такой элемент. Например, абзацы будут обтекать изображение, если для элемента
установлено свойство float
. Когда свойство float
применяется к нескольким элементам одновременно, это даёт возможность создать макет с обтекаемыми элементами расположенными рядом или напротив друг друга, как показано в многоколоночном макете. Свойство float
принимает несколько значений, два самых популярных - это left
и right
, они позволяют элементу располагаться слева или справа от своего родителя. Img {
float: left;
}
Давайте создадим общий макет страницы с шапкой вверху, двумя колонками в центре и подвалом внизу. В идеале эту страницу следует разметить с помощью элементов
Здесь элементы Section {
float: left;
}
aside {
float: right;
}
Для справки, обтекаемые элементы располагаются по краю родительского элемента. Если нет родителя, обтекаемый элемент будет располагаться по краю страницы. Когда мы устанавливаем элемент обтекаемым, то убираем его из обычного потока HTML-документа. Это приводит к тому, что ширина этого элемента по умолчанию становится шириной его содержимого. Иногда, например, когда мы создаём колонки для многократно используемого макета, такое поведение нежелательно. Это можно исправить путём добавления свойства width
с фиксированным значением для каждой колонки. Кроме того, чтобы обтекаемые элементы не соприкасались друг с другом, в результате чего содержимое одного элемента располагается рядом с другим, мы можем использовать свойство margin
, чтобы установить пространство между элементами. Ниже мы расширяем предыдущий блок кода, добавив margin
и width
для каждой колонки, чтобы лучше формировать наш желаемый результат. Section {
float: left;
margin: 0 1.5%;
width: 63%;
}
aside {
float: right;
margin: 0 1.5%;
width: 30%;
}
Для обтекаемого элемента также важно понимать, что элемент удаляется из обычного потока страницы и что у элемента может измениться значение display
, заданное по умолчанию. Свойство float
опирается на то, что у элемента значение display
задано как block
и может изменить значение display
у элемента по умолчанию, если он ещё не отображается как блочный элемент. Например, элемент, у которого display
указан как inline
, такой как строчный , игнорирует любые свойства height
или width
. Однако, если для строчного элемента указать float
, значение display
изменится на block
и тогда элемент уже может принимать свойства height
или width
. Когда мы применяем float
для элемента, то должны следить за тем, как это влияет на значение свойства display
. Для двух колонок вы можете установить float
, для одной колонки как left
, а для другой как right
, но для нескольких колонок нам придётся изменить наш подход. Скажем, к примеру, мы хотели бы получить ряд из трёх колонок между нашими элементами
Чтобы расположить эти три элемента Section {
float: left;
margin: 0 1.5%;
width: 30%;
}
Здесь у нас есть три колонки, все с равной шириной и значением margin
, а также с float
, заданным как left
. Свойство float
было первоначально разработано, чтобы позволить содержимому обтекать вокруг изображений. Для изображения может быть задано float
и всё содержимое вокруг этого изображения, естественно, обтекает вокруг него. Хотя это прекрасно работает для картинок, свойство float
на самом деле не было предназначено для использования в макете и с целью позиционирования и, таким образом, оно идёт с несколькими ловушками. Одной из этих ловушек является то, что иногда надлежащие стили не отображаются на элементе, который расположен рядом с обтекаемым элементом или является его родителем. Когда элемент установлен обтекаемым, то он убирается из обычного потока страницы и, как результат, стили элементов вокруг этого обтекаемого элемента могут получить негативное влияние. Часто значения свойств margin
и padding
интерпретируются некорректно, заставляя их сливаться с обтекаемым элементом. Другие свойства также могут быть затронуты. Другая ошибка состоит в том, что иногда нежелательный контент начинает обтекать элемент с float
. Удаление элемента из потока документа позволяет всем элементам вокруг обтекаемого элемента обходить его и задействовать любое доступное пространство вокруг обтекаемого элемента, что часто бывает нежелательно. В нашем предыдущем примере с двумя колонками, после того как мы добавили float
к элементам Чтобы предотвратить содержимое от обматывания вокруг обтекаемых элементов, нам нужно сделать очистку float
и вернуть страницу в её обычный поток. Мы рассмотрим как очистить float
, а затем взглянем на их содержимое. Очистка float
происходит с помощью свойства clear
, которое принимает несколько различных значений: наиболее часто используемые значения - left
, right
и both
. Div {
clear: left;
}
Значение left
очищает левые float
, в то время как значение right
очищает правые float
. Значение both
, однако, очистит левые и правые float
и часто является наиболее идеальным вариантом. Возвращаясь к нашему предыдущему примеру, если мы используем свойство clear
со значением both
для элемента Footer {
clear: both;
}
Вместо очистки float
, ещё одним вариантом является установка содержимого float
. Результат получится почти такой же, однако содержимое float
действительно гарантирует, что все наши стили будут отображаться надлежащим образом. Чтобы установить содержимое float
, обтекаемые элементы должны находиться внутри родительского элемента, он будет выступать в качестве контейнера, оставляя поток документа полностью обычным за его пределами. В стилях для этого родительского элемента представлен класс group
, как показано здесь: Group::before,
.group::after {
content: "";
display: table;
}
.group::after {
clear: both;
}
.group {
clear: both;
*zoom: 1;
}
Здесь немного что происходит, но, по сути, всё что CSS делает - очищает все обтекаемые элементы внутри элемента с классом group
и возвращает документ в обычный поток. Более конкретно, псевдоэлементы ::before
и ::after
, как указано в уроке 4, динамически генерируют элементы выше и ниже элемента с классом group
. Эти элементы не включают в себя какой-либо контент и отображаются как табличные элементы, подобно элементам блочным. Динамически генерируемый элемент после элемента с классом group
очищает float
внутри элемента с классом group
, так же, как и clear
ранее. И, наконец, элемент с классом group также очищает все float
, которые могут появиться до него на случай, если существует float
со значением left
или right
. Также сюда включена небольшая хитрость, которая заставляет старые браузеры играть красиво. Здесь больше кода, чем единственная команда clear: both
, но он может оказаться весьма полезным. Рассматривая наш макет страницы с двумя колонками мы могли бы обернуть
Group::before,
.group::after {
content: "";
display: table;
}
.group::after {
clear: both;
}
.group {
clear: both;
*zoom: 1;
}
section {
float: left;
margin: 0 1.5%;
width: 63%;
}
aside {
float: right;
margin: 0 1.5%;
width: 30%;
}
Показанная здесь техника известна как «clearfix» и часто встречается на других сайтах с именем класса clearfix или cf. Мы решили использовать имя класса group
, потому что он представляет группу элементов и лучше выражает содержимое. Когда для элементов задано float
важно следить за тем, как они влияют на поток страницы и убедитесь, что поток страницы сбрасывается путём очистки или через содержимое float, как надо. В противном случае, отслеживание float
может вызвать немало головной боли, особенно на страницах, содержащих несколько строк, в каждой из которых несколько колонок. Вернёмся к сайту Styles Conference и опробуем на нём добавление float
к некоторому содержимому. Теперь, когда мы можем использовать float
, давайте зададим его для основного Чтобы сделать это, добавим класс logo
к элементу
Пока мы здесь, добавим чуть больше деталей к нашему логотипу. Начнём с размещения элемента В CSS добавим границу по верху нашего логотипа и небольшой вертикальный padding
, чтобы логотип свободно «дышал».
Logo {
border-top: 4px solid #648880;
padding: 40px 0 22px 0;
float: left;
} Поскольку мы сделали элемент
Элемент В отличие от элемента Начнём с добавления класса primary-footer
к элементу
Теперь, когда класс primary-footer
установлен для элемента Для проверки - здесь мы выбираем элемент
, который должен находиться внутри элемента со значением primary-footer
у атрибута class
, такой как наш элемент Наконец, добавим небольшой padding
сверху и снизу элемента Primary-footer {
padding-bottom: 44px;
padding-top: 44px;
} С учётом всех этих изменений в элементах Рис. 5.01. С помощью нескольких float, элементы В дополнение к использованию float
, ещё один способ, которым мы можем позиционировать контент - это применение свойства display
в сочетании со значением inline-block
. Метод с inline-block
, как мы ещё обсудим, в первую очередь полезен для компоновки страниц или для размещения элементов в линию рядом друг с другом. Напомним, что значение inline-block
для свойства display
отображает элементы в линию и позволяет им принимать все свойства блочной модели, включая height
, width
, padding
, border
и margin
. Применение inline-block
позволяет нам в полной мере воспользоваться блочной моделью, не беспокоясь об очистке каких-либо float
. Давайте взглянем на наш трёхколоночный пример с самого начала. Начнём мы, сохраняя наш HTML таким:
Теперь вместо float
для наших трёх элементов Section {
display: inline-block;
margin: 0 1.5%;
width: 30%;
}
К сожалению, одного этого кода недостаточно чтобы сделать трюк и последний элемент Есть несколько методов, как удалить пространство между строчно-блочными элементами и некоторые из них более сложные, чем другие. Мы собираемся сосредоточиться на двух самых простых методах, каждый из которых происходят внутри HTML. Первое решение - это поместить каждый новый открывающий тег элемента
Написание строчно-блочных элементов таким образом гарантирует, что пространства между такими элементами в HTML не существует. Следовательно, пространство и не появится при отображении страницы. Ещё один метод для удаления пространства между строчно-блочными элементами состоит в открытии комментария HTML непосредственно после закрывающего тега элемента. Затем закройте комментарий непосредственно перед открывающим тегом следующего элемента. Это позволяет строчно-блочным элементам начинаться и завершаться на отдельных строках в HTML и «закомментирует» любое потенциальное пространство между элементами. В результате код будет выглядеть следующим образом:
Ни один из этих вариантов не является совершенным, но они полезны. Я склоняюсь в пользу применения комментариев для лучшей организации, но какой вариант вы выберете полностью зависит от вас. При создании сайта всегда лучше написать модульные стили, которые могут быть повторно задействованы в других местах, а многократно используемые макеты находятся в верхней части списка повторно применяемого кода. Макеты могут быть созданы с помощью float
или строчно-блочных элементов, но что работает лучше и почему? Вопрос что лучше для структуры страницы - обтекаемые или строчно-блочные элементы открыт для обсуждения. Мой подход заключается в использовании строчно-блочных элементов для создания сетки или макета страницы, а затем задействовать float
, когда мне хочется чтобы контент обтекал вокруг данного элемента (для чего float
и были предназначены при работе с изображениями). Вообще, я также считаю, что со строчно-блочными элементами легче работать. Тем не менее, используйте то, что работает лучше для вас. Если с одним подходом вы знакомы лучше чем с другим, тогда задействуйте его. В настоящее время в работе появились новые спецификации CSS - в частности, свойства flex- и grid-, которые помогут решить, как лучше всего сверстать страницы. Следите за этими методами, когда они начнут всплывать. С твёрдым пониманием многократно используемых макетов, пришло время внедрить один на наш сайт Styles Conference. Для сайта Styles Conference мы создадим трёхколоночный макет используя строчно-блочные элементы. Мы сделаем это так, чтобы получить три колонки одинаковой ширины или две колонки с общей шириной, разделённой между ними как 2/3 для одной и 1/3 для другой. Для начала мы создадим классы, определяющие ширину этих колонок. Эти два класса мы назовём col-1-3
для одной трети и col-2-3
для двух третей. В разделе «Сетка» нашего файла main.css перейдём вперед и определим эти классы и соответствующую им ширину. Col-1-3 {
width: 33.33%;
}
.col-2-3 {
width: 66.66%;
} Мы хотим чтобы обе колонки отображались как строчно-блочные элементы. Нам также надо убедиться, что вертикальное выравнивание у них задано по верхней части каждой колонки. Давайте создадим два новых селектора, которые совместно будут использовать display
и vertical-align
. Col-1-3,
.col-2-3 {
display: inline-block;
vertical-align: top;
}
Взгляните на CSS снова. Мы создали два селектора класса col-1-3
и col-2-3
разделённых запятой. Запятая в конце первого селектора означает, что за ней следует другой селектор. После второго селектора идёт открывающая фигурная скобка, которая сообщает что начинается описание стиля. С помощью запятой разделяющей селекторы мы можем привязать один стиль к нескольким селекторам одновременно. Мы хотим поместить некоторое пространство между колонок, которое поможет разбить содержимое. Это можно сделать, добавив горизонтальный padding
к каждой колонке. Это хорошо работает, однако, когда две колонки располагаются рядом друг с другом, ширина пространства между ними будет вдвое больше, чем пространство от внешнего края. Чтобы уравновесить это, мы поместим все наши колонки в сетку и добавим к ней тот же padding
. Давайте воспользуемся классом grid
, чтобы определить нашу сетку, а затем зададим одинаковый горизонтальный padding
для классов grid
, col-1-3
и col-2-3
. С запятыми, снова разделяющих наши селекторы, наш CSS выглядит следующим образом: Grid,
.col-1-3,
.col-2-3 {
padding-left: 15px;
padding-right: 15px;
} Когда мы устанавливаем горизонтальный padding
, нам нужно быть осторожными. Помните, в прошлом уроке мы создали контейнер с классом container
по центру всего нашего контента на странице с шириной 960 пикселей. В данный момент, если бы мы поставили элемент с классом grid
внутрь элемента с классом container
, то их горизонтальные padding
сложились бы вместе и наши колонки не будут отображаться пропорционально ширине остальной части страницы. Мы осуществим это, разбивая набор старых правил container
на следующее: Container,
.grid {
margin: 0 auto;
width: 960px;
}
.container {
padding-left: 30px;
padding-right: 30px;
}
Теперь любой элемент с классом container
или grid
будет 960 пикселей в ширину и располагаться по центру страницы. Кроме того, мы сохранили существующий горизонтальный padding
для любого элемента с классом container
путём перемещения его в новый, отдельный набор правил. Хорошо, всю тяжёлую необходимую часть по настройке сетки завершили. Теперь пришло время для работы с нашим HTML и просмотра, как эти классы действуют. Мы начнём с тизеров на главной странице, в файле index.html, выровняв их по трём колонкам. В настоящее время тизеры обёрнуты элементом
...
...
...
...
И, наконец, поскольку каждая наша колонка является строчно-блочным элементом, нам следует убедиться что мы удалили пустое пространство между ними. Чтобы сделать это мы воспользуемся комментариями и добавим немного документации к каждому разделу, чтобы лучше организовать свой код.
...
...
...
Для проверки - в строке 3 мы оставили комментарий, идентифицирующий раздел «Спикеры», который за ним следует. В конце строки 7 мы открываем комментарий сразу после закрывающего тега
. Внутри этого комментария, в строке 9 мы определяем следующий раздел «Расписание». Затем закрываем комментарий в начале строки 11, сразу перед открывающим тегом Теперь у нас есть повторно используемая трёхколоночная сетка, которая поддерживает разные расстановки, с использованием ширины колонок как 1/3 и 2/3. Наша главная страница теперь содержит три колонки, разделяя все тизеры. Рис. 5.02. Главная страница Styles Conference теперь включает трёхколоночный макет Ниже вы можете просмотреть сайт Styles Conference в его нынешнем состоянии, а также скачать исходный код сайта на данный момент. Рано или поздно каждый пожелает точно позиционировать элемент, но float
или строчно-блочные элементы не позволяют проделать такой трюк. Обтекаемые элементы, которые удаляют элемент из потока страницы, часто приводят к нежелательным результатам, поскольку окружающие элементы обтекают вокруг элемента с float
. Строчно-блочные элементы, если только мы не создаём колонки, могут быть довольно неудобны, когда дело касается правильного положения. Для подобных ситуаций мы можем использовать свойство position
в сочетании со свойствами смещения блока. Свойство position
определяет, как элемент позиционируется на странице и будет ли он отображаться в обычном потоке документа. Оно применяется в сочетании со свойствами смещения блока - top
, right
, bottom
и left
, которые точно определяют, где элемент будет расположен путём перемещения элемента в разных направлениях. По умолчанию у каждого элемента значение position
установлено как static
, это означает, что элемент существует в обычном потоке документа и не принимает какие-либо свойства для его смещения. Значение static
наиболее часто переписывается значением relative
или absolute
, которые мы рассмотрим дальше. Значение relative
для свойства position позволяет элементам отображаться в обычном потоке страницы, резервируя место для элемента как предполагалось и не позволяя другим элементам его обтекать. Однако, оно также позволяет модифицировать положение элемента с помощью свойств смещения. К примеру, рассмотрим следующие HTML и CSS:
Div {
height: 100px;
width: 100px;
}
.offset {
left: 20px;
position: relative;
top: 20px;
}
Здесь для второго элемента Для относительно позиционированных элементов важно знать, что свойства смещения блока определяют, куда элемент будет перемещён, учитывая его исходное положение. Таким образом, свойство left
со значением 20 пикселей фактически толкает элемент вправо на 20 пикселей. Свойство top
со значением 20 пикселей затем будет толкать элемент вниз на 20 пикселей. Когда мы позиционируем элемент с помощью свойств смещения, элемент перекрывает элемент под ним, а не сдвигает его вниз, как это делают свойства margin
или padding
. Значение absolute
для свойства position
отличается от значения relative
тем, что элемент с абсолютным позиционированием не появляется в обычном потоке документа, исходное пространство и положение абсолютно позиционируемого элемента не резервируется. Кроме того, абсолютно позиционируемые элементы перемещаются относительно их ближайшего относительно позиционированного родительского элемента. Если относительно позиционированного родителя не существует, то абсолютно позиционированный элемент будет позиционироваться относительно элемента
Section {
position: relative;
}
div {
position: absolute;
right: 20px;
top: 20px;
}
В этом примере элемент Для относительно позиционированных элементов свойства смещения определяют, в каком направлении элемент будет перемещён относительного самого себя. Для абсолютно позиционируемых элементов свойства смещения определяют, в каком направлении элемент будет перемещён относительно его ближайшего относительно позиционированного родителя. В результате свойств right
и top
, элемент Поскольку элемент Изучение позиционирования содержимого в HTML и CSS является огромным шагом в сторону освоения этих языков. Добавьте к этому блочную модель и вот мы уверенно движемся по пути превращения во фронтенд-разработчиков.
<НЕАD>
nepBbiu позиционированный текстН1>
Н1>
<НЕАD><ТIТLЕ>ПозиционированиеТIТLЕ>НЕАD>
riepBbiM позиционированный текст
Н1>
Второй позиционированный текстН1>
height:100;margin: top: 10">
Обзор доступных способов позиционирования
Опции для позиционирования
Различия между основными способами позиционирования
Позиционирование элементов с абсолютным типом позиционирования
Абсолютно позиционированные элементы игнорируют свойство float
Абсолютно позиционированные строчные элементы становятся блочными
У абсолютно позиционированных элементов нет схлопывания внешних отступов
Позиционирование элементов с пикселями и процентами
Заключение
До некоторого времени я, как и многие из вас, пользовался двумя способами:
Главный недостаток обоих способов заключается в том, что, если блоки нужно выравнять по нижней границе или по средней линии относительно друг друга, то приходится методом подбора смещать блоки по вертикали, задавая им либо top: anyValue, либо margin-top: anyValue. А у первого способа плюс ко всему есть ещё один, не то чтобы недостаток, но неприятная мелочь. Это необходимость очищать поток с помощью clearFix"a, overflow или дополнительного дива.
Итак способ номер 3. Для начала код:Собственно HTML
Copy Source | Copy HTML
Собственно CSS
Copy Source | Copy HTML
Пояснения
Суть способа заключается в том, чтобы наложить блоки друг на друга посредством margin-right: -100% и содержимое правого блока выровнять по правому краю с помощью text-align: right.
Оба блока (right и left) желательно записывать в одну строку, иначе из-за символа переноса строки правый блок будет чуть-чуть вылезать за границы блока-родителя.
Ссылкам обязательно нужно ставить position: relative, иначе из-за наложения блоков некоторые могут быть некликабельные.Плюсы способа
Главный плюс в том, что теперь для наших блоков начинает работать vertical-align. И мы легко можем выровнять их и по верхней границе и по нижней и по центру.Минусы способа
А главный минус заключается в том, что, применяя этот способ, мы должны быть твёрдо уверены, что содержимое блоков не увеличится до такой степени, что они начнут перекрывать друг друга (к слову говоря, способ с флоутами лишён этого недостатка, так как при увеличении содержимого блоков, они будут вставать друг под друга).P.S.
Я не встречал такого способа в интернете, посему просьба: если кто-то найдёт аналогичную статью опубликованную раньше, сообщите мне пожалуйста.Upd.
В комментариях моё внимание внимание обратили на способ, использующий text-align: justify. Этот способ тоже хорош, но у него есть два недостатка. Во-первых он требует введения дополнительного элемента, эмулирующего последнюю строку текстового блока, а во-вторых, он не будет работать в IE6-IE7 для блочных элементов.
Позиционирование через float
float на практике
Демонстрация макета без float
Демонстрация макета с float
float могут изменить значение display у элемента
Демонстрация трёхколоночного макета с float
Очистка и содержимое float
Демонстрация макета без очистки float
Очистка float
Демонстрация макета с очисткой float
Содержимое float
Демонстрация макета с содержимым float
На практике
внутри элемента
. Затем внутри нашего CSS добавим новый раздел стилей для основного заголовка. В этом разделе мы выберем элемент
с классом logo
и установим float
как left
.
Styles Conference
/*
========================================
Основной заголовок
========================================
*/
.logo {
float: left;
}
или разрыва строки между словами «Styles» и «Conference», чтобы заставить текст нашего логотипа располагаться на двух строках.
Styles
Conference
обтекаемым, то хотим установить содержимое float
. Ближайшим родителем для
является элемент
Позиционирование через inline-block
inline-block на практике
Демонстрация элементов inline-block с пробелом
Удаление пространства между строчно-блочными элементами
Демонстрация элементов inline-block без пробелов
Создание многократно используемых макетов
На практике
Демонстрация и исходный код
Уникальное позиционирование элементов
Относительное позиционирование
Демонстрация относительного позиционирования
Абсолютное позиционирование
Демонстрация абсолютного позиционирования
Резюме