Позиционирование 2 элементов на одной линии с помощью bootstrap
У меня есть страница с сеткой col-md-8
и col-md-4
. Чего я пытаюсь достичь, так это в разделе col-md-4
иметь два элемента (изображения большого пальца) на одной строке, а затем перейти на следующую строку/строку еще на два изображения и так далее. Структура HTML выглядит следующим образом:
<div>
<div>
<!-- some text here -->
</div>
<div>
<div>
<div>
<img src="image.jpg">
</div>
</div>
</div>
</div>
Вот JSFIDDLE я пытаюсь получить эти 4 маленьких изображения справа от большого изображения и 2×2 на линии.
html css twitter-bootstrapПоделиться Источник John 22 апреля 2015 в 13:44
5 ответов
2
Попробуйте выполнить следующий код
HTML
<div>
<div>
<img src="http://www. extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg" />
</div>
<div>
<div>
<div>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg" />
</div>
<div>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg" />
</div>
<div>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg" />
</div>
<div>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg" />
</div>
</div>
</div>
Поделиться Nilesh Mahajan 22 апреля 2015 в 13:52
1
Не знаю, как вы хотите расположить два изображения на каждой строке, но вы можете использовать такой подход, который в основном состоит в том, чтобы иметь row
для каждой строки изображений:
<div> <div> <div> <div> <img src="http://www. extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"> <img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"> </div> </div> <div> <div> <img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"> <img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"> </div> </div> </div> </div>
Вы могли бы пойти дальше, имея каждое изображение в определенном размере div
, например, иметь каждое изображение в col-md-6
div, а не оба в col-md-12
, но это зависит от того, что вы хотите сделать.
Кроме того, изображения в bootstrap 3 по умолчанию не реагируют, поэтому вам нужно будет добавить класс img-responsive
ко всем вашим изображениям, чтобы они были правильно изменены.
Поделиться martincarlin87 22 апреля 2015 в 13:56
1
В вашем конкретном случае отсутствовало закрытие divs AND окно jsfiddle было слишком узким, чтобы реагировать на col-md-4.
Я исправил закрывающиеся дивы и перешел на col-xs-4. Вы можете увидеть исправленный fiddle здесь: http://jsfiddle.net/1ezk5oev/
<div>
<div>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"/>
</div>
<div>
<div>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"/>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"/>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"/>
<img src="http://www. extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"/>
</div>
</div>
</div>
Поделиться gmoore 22 апреля 2015 в 13:58
1
Следующий код решит вашу проблему. Вы также захотите заменить свой стиль на class='img-responsive'
, если хотите, чтобы ваши изображения изменили свой размер соответственно.
<div>
<div>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"/>
</div>
<div>
<div>
<div>
<div>
<div>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"/>
</div>
<div>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428. jpg"/>
</div>
</div>
<div>
<div>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"/>
</div>
<div>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"/>
</div>
</div>
</div>
</div>
</div>
Поделиться Unknown 22 апреля 2015 в 13:58
1
Лично я считаю, что использование таблиц для чего-то подобного-лучший способ. Если вам это тоже нравится, используйте этот пример:
<table>
<tr>
<td rowspan="2">
<div>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"/>
</div>
</td>
<td>
<div>
<div>
<img src="http://www. extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"/>
</div>
</div>
</td>
<td>
<div>
<div>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"/>
</div>
</div>
</td>
</tr>
<tr>
<td>
<div>
<div>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"/>
</div>
</div>
</td>
<td>
<div>
<div>
<img src="http://www.extremetech.com/wp-content/uploads/2013/09/4Vln8-640x428.jpg"/>
</div>
</div>
</td>
</tr>
Код также можно найти по адресу: http://jsfiddle.net/9se6Lep0/
Поделиться Gravinco 22 апреля 2015 в 14:02
Похожие вопросы:
Позиционирование двух блоков на одной линии
У меня есть этот код HTML: <span class=left> <img class=avatar src=image. jpg /> </span> <span class=right> Lorem ipsum dolor sit amet, nunc euismod nisl nam euismod, quis…
Позиционирование Div на одной линии
У меня проблема с некоторыми дивами. Короче говоря, вот что мне нужно: 2 дива с определенной шириной (одинаковой шириной) — один с поплавком слева и один с правым, и третий див, который занимает все…
Контролируйте количество элементов на каждой гибкой линии, когда контейнер настроен на обертывание
Я использую css flexbox для распределения ряда элементов в контейнере. У меня есть такой гибкий контейнер: .container{ display: flex; flex-flow: row wrap; align-content : center; justify-content :…
Как выровнять два изображения на одной линии без пробела между ними с помощью Bootstrap
У меня есть два изображения, которые я хотел бы разместить на одной линии с bootstrap. Это изображение один А это изображение два В основном то, чего я хочу достичь с помощью bootstrap, заключается. ..
как изменить порядок элементов с помощью bootstrap и точек останова
Есть ли способ сделать это с помощью bootstrap? Я попробовал с pull-right/push-left, но нижний div (светло-синий) находится в одной линии с желтым div, а не в верхней. <div…
Отзывчивые виды нескольких кнопок boostrap, расположенных на одной линии
У меня есть 5 кнопок bootstrap, расположенных рядом на одной линии. Они прекрасно смотрятся на рабочем столе. Скриншот- Но на меньшем видовом экране кнопки расположены над двумя линиями без…
Bootstrap 4 элементы сетки не находятся в одной горизонтальной линии
Я использую Bootstrap 4.0 Grid system в Angular для создания макета. Но у меня есть это: Похоже, что текст в оранжевом поле не находится в одной горизонтальной линии с содержимым других. Это мой…
Позиционирование элементов с помощью bootstrap
Как более точно расположить элементы с помощью bootstrap? Пример: теперь у меня есть div с классом . bg внутри этого div есть контент, который позиционируется через bootstrap, BUT когда я использую…
Как расположить два элемента на одной линии с помощью Bootstrap 4 Flex?
У меня есть эти два элемента: h3 и выпадающая кнопка, но я не нашел способа расположить их на одной линии с помощью bootstrap 4 flex. У меня есть это я пытаюсь это сделать это мой код.: <div>…
Выровняйте 2 <p> элементов на одной линии
Выровняйте 2 <p> элементов на одной линии Я хочу выровнять оба элемента <p> на одной линии, но один слева, другой справа. <p style=text-align:left>Copyright © {$date_year}…
CSS Макет. Свойство Position. Уроки для начинающих. W3Schools на русском
Свойство position
указывает тип метода позиционирования, используемого для элемента (статический, относительный, фиксированный, абсолютный или закрепленный — static, relative, fixed, absolute или sticky).
Свойство position
Свойство position
определяет тип метода позиционирования, используемого для элемента.
Есть пять разных значений position (позиции):
static
— статическийrelative
— относительныйfixed
— фиксированныйabsolute
— абсолютныйsticky
— закреплённый
Затем элементы располагаются с использованием свойств top, bottom, left и right. Однако эти свойства не будут работать, если сначала не установлено свойство position
. Они также работают по-разному в зависимости от значения position.
position: static;
HTML-элементы по умолчанию расположены статически.
На статические элементы не влияют свойства top, bottom, left и right.
Элемент с position: static;
не позиционируется каким-либо особым образом; он всегда располагается в соответствии с обычным потоком страницы:
Этот элемент <div> имеет position: static;
Вот CSS, который используется:
position: relative;
Элемент с position: relative;
позиционируется относительно своего нормального положения.
Установка свойств top, right, bottom и left относительно позиционированного элемента приведет к его отклонению от его нормального положения. Другое содержимое не будет откорректировано, чтобы вписаться в любой пробел, оставленный элементом.
Этот элемент <div> имеет position: relative;
Вот CSS, который используется:
position: fixed;
Элемент с position: fixed;
располагается относительно области просмотра, что означает, что он всегда остается на том же месте, даже если страница прокручивается. Свойства top, right, bottom и left используются для позиционирования элемента.
Фиксированный (fixed) элемент не оставляет пробела на странице, где он обычно находился бы.
Обратите внимание на фиксированный элемент в правом нижнем углу данной страницы. Вот CSS, который используется:
Этот элемент <div> имеет position: fixed;
position: absolute;
Элемент с position: absolute;
позиционируется относительно ближайшего позиционированного предка (вместо позиционирования относительно окна просмотра, как фиксированный).
Однако, если элемент с абсолютным позиционированием не имеет позиционированных предков, он использует тело документа и перемещается вместе с прокруткой страницы.
Примечание: «Позиционируемый» элемент — это тот, чья позиция что угодно, кроме static
.
Вот простой пример:
Этот элемент имеет position: relative;Этот элемент <div> имеет position: absolute;
Вот CSS, который используется:
Пример
div.relative {position: relative;
width: 400px;
height: 200px;
border: 3px solid #73AD21;
}
div.absolute {
position: absolute;
top: 80px;
right: 0;
width: 200px;
height: 100px;
border: 3px solid #73AD21;
}
position: sticky;
Элемент с position: sticky;
(прикреплённый) позиционируется на основе позиции прокрутки пользователя.
Элемент sticky переключается между relative
и fixed
, в зависимости от положения прокрутки. Он позиционируется относительно до тех пор, пока в окне просмотра не будет достигнута заданная позиция смещения, а затем он «закрепится» на месте (например, position:fixed).
Примечание: Internet Explorer, Edge 15 и более ранние не поддерживают position: sticky. Safari требует -webkit-prefix (см. пример ниже). Вы также должны указать хотя бы одно из значений: top
, right
, bottom
или left
для работы sticky позиционирования.
В этом примере sticky элемент придерживается верхней части страницы (top: 0
), когда вы достигнете своей позиции прокрутки.
Пример
div.sticky {
position: -webkit-sticky; /* Safari */
position:
sticky;
top: 0;
background-color: green;
border: 2px solid #4CAF50;
}
Перекрывающиеся элементы
Когда элементы располагаются на странице, они могут перекрывать другие элементы.
Свойство z-index
определяет порядок стека элемента (какой элемент должен быть расположен перед или позади других, т.е. какой элемент перекрывает другой).
Элемент может иметь положительный или отрицательный порядок в стеке:
Поскольку изображение имеет z-index -1, оно будет помещено за текстом, т.е. текст будет находится сверху изображения.
Элемент с более высоким порядком стека всегда находится перед элементом с более низким порядком стека.
Примечание: Если два позиционированных элемента перекрываются без указания z-index
, элемент, расположенный последним в HTML коде, будет показан сверху.
Позиционирование текста в изображении
Как разместить текст поверх изображения:
Больше примеров
Установить форму элемента
Этот пример демонстрирует, как установить форму элемента. Элемент обрезается до этой формы и отображается.
Проверьте себя с помощью упражнений!
Все CSS свойства позиционирования
Свойство | Описание |
---|---|
bottom | Устанавливает нижний край поля для позиционированного блока |
clip | Закрепляет абсолютно позиционированный элемент |
left | Устанавливает край левого поля для позиционированного блока |
position | Определяет тип позиционирования для элемента |
right | Устанавливает правый край поля для позиционированного блока |
top | Устанавливает верхний край поля для позиционированного блока |
z-index | Устанавливает порядок стека элемента |
Bootstrap Бутстрап 4 Flex
Bootstrap 4 Flex
Используйте классы Flex для управления компоновкой компонентов Bootstrap 4.
Flexbox
Самая большая разница между Bootstrap 3 и Bootstrap 4 заключается в том, что BootStrap 4 теперь использует Flexbox, а не float, для обработки макета.
Модуль компоновки гибких коробок упрощает разработку гибкой адаптивной структуры макета без использования float или позиционирования. Если вы новичок в Flex, вы можете прочитать об этом в нашем CSS Flexbox учебник.
Примечание: Flexbox не поддерживается в IE9 и более ранних версиях.
Если вам нужна поддержка IE8-9, используйте Bootstrap 3. Это наиболее стабильная версия Bootstrap, и она по-прежнему поддерживается командой для критических исправлений и изменений в документации. Тем не менее, новые функции не будут добавлены к нему.
Для создания контейнера Flexbox и преобразования прямых дочерних элементов в элементы Flex используйте d-flex
класс:
Пример
Flex item 1
Flex item 2
Flex item 3
Пример
<div>
<div>Flex item 1</div>
<div>Flex
item 2</div>
<div>Flex item 3</div>
</div>
Чтобы создать встроенный контейнер Flexbox, используйте d-inline-flex
класс:
Пример
Flex item 1
Flex item 2
Flex item 3
Пример
<div>
<div>Flex item 1</div>
<div>Flex
item 2</div>
<div>Flex item 3</div>
</div>
Горизонтальное направление
Используется . flex-row
для отображения элементов Flex горизонтально (бок о бок). Это значение по умолчанию.
Совет: используйте .flex-row-reverse
Выравнивание по горизонтали по правому краю:
Пример
Flex item 1
Flex item 2
Flex item 3
Flex item 1
Flex item 2
Flex item 3
Пример
Flex item 1
Flex item 2
Flex item 3
<div
class=»d-flex flex-row-reverse bg-secondary»>
<div>Flex
item 1</div>
<div>Flex item 2</div>
<div>Flex item 3</div>
</div>
Вертикальное направление
Используется .flex-column
для отображения элементов Flex вертикально (поверх друг друга) или для изменения .flex-column-reverse
вертикального направления:
Пример
Flex item 1
Flex item 2
Flex item 3
Flex item 1
Flex item 2
Flex item 3
Пример
Flex item 1
Flex item 2
Flex item 3
<div
class=»d-flex flex-column-reverse»>
<div>Flex
item 1</div>
<div>Flex item 2</div>
<div>Flex item 3</div>
</div>
Выравнивание содержимого
Используйте .justify-content-*
классы для изменения выравнивания элементов Flex. Допустимые классы start
(по умолчанию),,, end
center
between
или around
:
Пример
Flex item 1
Flex item 2
Flex item 3
Flex item 1
Flex item 2
Flex item 3
Flex item 1
Flex item 2
Flex item 3
Flex item 1
Flex item 2
Flex item 3
Flex item 1
Flex item 2
Flex item 3
Пример
<div>…</div>
<div>…</div>
<div>…</div>
<div>…</div>
<div>…</div>
Заливка/равная ширина
Используйте .flex-fill
для элементов Flex, чтобы заставить их в равной ширины:
Пример
Flex item 1
Flex item 2
Flex item 3
Пример
<div>
<div>Flex
item 1</div>
<div>Flex item 2</div>
<div>Flex item 3</div>
</div>
Grow
Используйте для .flex-grow-1
элемента Flex, чтобы занять оставшуюся часть пространства. В приведенном ниже примере первые два элемента Flex занимают необходимое пространство, в то время как последний элемент занимает оставшуюся часть доступного пространства:
Пример
Flex item 1
Flex item 2
Flex item 3
Пример
<div>
<div>Flex
item 1</div>
<div>Flex item 2</div>
<div>Flex item 3</div>
</div>
Совет: Используйте .flex-shrink-1
на Flex элемент, чтобы сделать его сжатие, если это необходимо.
Order
Изменение визуального порядка конкретных элементов Flex с помощью .order
классов. Допустимые классы от 0 до 12, где наименьшее число имеет наивысший приоритет (Order-1 отображается перед порядком-2 и т.д.):
Пример
Flex item 1
Flex item 2
Flex item 3
Пример
<div>
<div>Flex
item 1</div>
<div>Flex item 2</div>
<div>Flex item 3</div>
</div>
Автоматические поля
С легкостью добавляйте автоматические поля в элементы Flex .mr-auto
(нажимайте элементы вправо) или с помощью .ml-auto
(передвиньте элементы влево):
Пример
Flex item 1
Flex item 2
Flex item 3
Flex item 1
Flex item 2
Flex item 3
Пример
Flex item 1
Flex item 2
Flex item 3
<div>
<div
class=»p-2 bg-info»>Flex item 1</div>
<div>Flex
item 2</div>
<div>Flex item
3</div>
</div>
Обернуть
Управление переносом элементов Flex в контейнер Flex с помощью .flex-nowrap
(по умолчанию) .flex-wrap
или .flex-wrap-reverse
.
Нажмите на кнопки ниже, чтобы увидеть разницу между тремя классами, по Чанг в упаковке Flex элементов в примере поле:
flex-wrap flex-wrap-reverse flex-nowrap
Пример
Flex item 1
Flex item 2
Flex item 3
Flex item 4
Flex item 5
Flex item 6
Flex item 7
Flex item 8
Flex item 9
Flex item 10
Flex item 11
Flex item 12
Flex item 13
Flex item 14
Flex item 15
Flex item 16
Flex item 17
Flex item 18
Flex item 19
Flex item 20
Flex item 21
Flex item 22
Flex item 23
Flex item 24
Flex item 25
Пример
..<div>..</div>
<div>..</div>
Выравнивание содержимого
Управление вертикальным выравниванием собранных элементов Flex с помощью .align-content-*
классов. Допустимые классы .align-content-start
(по умолчанию),,,, .align-content-end
.align-content-center
.align-content-between
.align-content-around
и .align-content-stretch
.
Примечание: Эти классы не влияют на отдельные строки элементов Flex.
Нажмите на кнопки ниже, чтобы увидеть разницу между пятью классами, изменив вертикальное выравнивание элементов Flex в поле пример:
align-content-start align-content-end align-content-center align-content-around align-content-stretch
Example
Flex item 1
Flex item 2
Flex item 3
Flex item 4
Flex item 5
Flex item 6
Flex item 7
Flex item 8
Flex item 9
Flex item 10
Flex item 11
Flex item 12
Flex item 13
Flex item 14
Flex item 15
Flex item 16
Flex item 17
Flex item 18
Flex item 19
Flex item 20
Flex item 21
Flex item 22
Flex item 23
Flex item 24
Flex item 25
Пример
..<div>..</div>
<div>..</div>
<div>..</div>
<div>..</div>
Выравнивание элементов
Управление вертикальным выравниванием отдельных строк элементов Flex с помощью .align-items-*
классов. Допустимые классы .align-items-start
:, .align-items-end
, .align-items-center
.align-items-baseline
и .align-items-stretch
(по умолчанию).
Нажмите на кнопки ниже, чтобы увидеть разницу между пятью классами:
align-items-start align-items-end align-items-center align-items-baseline align-items-stretch
Пример
Flex item 1
Flex item 2
Flex item 3
Пример
..<div>..</div>
<div>..</div>
<div>..</div>
<div>..</div>
Выравнивание себя
Управление вертикальным выравниванием заданного элемента Flex с классами .align-self-*
. Допустимые классы .align-self-start
:, .align-self-end
, .align-self-center
.align-self-baseline
и .align-self-stretch
(по умолчанию).
Нажмите на кнопки ниже, чтобы увидеть разницу между пятью классами:
align-self-start align-self-end align-self-center align-self-baseline align-self-stretch
Example
Flex item 1
Flex item 2
Flex item 3
Пример
<div>
<div
class=»p-2 border»>Flex item 1</div>
<div>Flex item 2</div>
<div
class=»p-2 border»>Flex item 3</div>
</div>
Адаптивные классы Flex
Все классы Flex оснащены дополнительными адаптивными классами, что упрощает задание определенного класса Flex для определенного размера экрана.
*
символ может быть заменен SM, MD, LG или XL, который представляет малые, средние, большие или XLarge экраны.
Класс | Описание | |
---|---|---|
Flex Container | ||
.d-*-flex | Создает контейнер Flexbox для различных экранов | |
.d-*-inline-flex | Создает встроенный Flexbox контейнер для различных экранов | |
Direction | ||
.flex-*-row | Отображать гибкие элементы по горизонтали на разных экранах | |
.flex-*-row-reverse | Отображение гибких элементов по горизонтали и по правому краю на разных экранах | |
.flex-*-column | Отображать гибкие элементы по вертикали на разных экранах | |
.flex-*-column-reverse | Отображать гибкие элементы по вертикали, с обратным порядком, на разных экранах | |
Justified Content | ||
.justify-content-*-start | Отображать элементы Flex с начала (по левому краю) на разных экранах | |
.justify-content-*-end | Отображение элементов Flex в конце (по правому краю) на разных экранах | |
.justify-content-*-center | Отображение элементов Flex в центре контейнера Flex на разных экранах | |
.justify-content-*-between | Отображать гибкие элементы в «между» на разных экранах | |
.justify-content-*-around | Отображать гибкие элементы «вокруг» на разных экранах | |
Fill / Equal Width | ||
.flex-*-fill | Принудить элементы Flex к одинаковой ширине на разных экранах | |
Grow | ||
.flex-*-grow-0 | Не делайте элементы растут на разных экранах | |
.flex-*-grow-1 | Сделать элементы растут на разных экранах | |
Shrink | ||
.flex-*-shrink-0 | Не делайте элементы термоусадочные на разные экраны | |
.flex-*-shrink-1 | Сжатие элементов на разных экранах | |
Order | ||
.order-*-0-12 | Изменение порядка от 0 до 12 на маленьких экранах | |
Wrap | ||
.flex-*-nowrap | Не оборачивать элементы на разных экранах | |
.flex-*-wrap | Перенос элементов на различные экраны | |
.flex-*-wrap-reverse | Реверсировать обтекание элементов на разных экранах | |
Align Content | ||
.align-content-*-start | Выравнивание собранных элементов с начала на разных экранах | |
.align-content-*-end | Выравнивание собранных элементов в конце на разных экранах | |
.align-content-*-center | Выравнивание собранных элементов в центре на разных экранах | |
.align-content-*-around | Выравнивание собранных элементов «вокруг» на разных экранах | |
.align-content-*-stretch | Растянуть собранные элементы на разных экранах | |
Align Items | ||
.align-items-*-start | Выравнивание отдельных рядов элементов с начала на разных экранах | |
.align-items-*-end | Выравнивание отдельных рядов элементов в конце на разных экранах | |
.align-items-*-center | Выравнивание одиночных рядов элементов в центре на разных экранах | |
.align-items-*-baseline | Выравнивание отдельных строк элементов на базовой линии на разных экранах | |
.align-items-*-stretch | Растянуть отдельные ряды элементов на разных экранах | |
Align Self | ||
.align-self-*-start | Выравнивание элемента Flex с начала на разных экранах | |
.align-self-*-end | Выравнивание элемента Flex в конце на разных экранах | |
.align-self-*-center | Выравнивание элемента Flex в центре на разных экранах | |
.align-self-*-baseline | Выравнивание элемента Flex по базовой линии на разных экранах | |
.align-self-*-stretch | Растянуть гибкий элемент на разных экранах |
FAQ / Методология / БЭМ
Возникли вопросы по БЭМ? Мы поможем быстро найти ответы.
Почему БЭМ?
Блоки и элементы
Модификаторы и миксы
CSS
JavaScript
Зачем нужен i-bem.js, если есть jQuery?
У меня другой вопрос
Если вы не нашли ответ на свой вопрос, свяжитесь с нами на форуме.
В чем отличие БЭМ от OOCSS, AMCSS, SMACSS, SUITCSS?
БЭМ работает не только с CSS, но и с JavaScript.
БЭМ больше схож с Web Components, чем с перечисленными решениями для CSS.
БЭМ предоставляет комплексное решение по созданию архитектуры проекта и помогает организовать процессы разработки.
Подробнее читайте в разделе Применение методологии для решения задач веб-разработки.
В чем разница между БЭМ и Web Components?
Поддержка браузеров
Web Components не поддерживается в Safari, iOS Safari, Internet Explorer, Firefox.
БЭМ работает во всех браузерах.
Инкапсуляция
В Web Components реализована через Shadow DOM.
В БЭМ — с помощью элементов блока.
Работа шаблонов
В Web Components шаблоны всегда выполняются в браузере. Это может потребовать дополнительных решений проблем с индексацией.
В БЭМ генерация шаблона возможна на этапе разработки. Это позволяет отдавать готовый HTML. Шаблоны могут выполняться как в браузере, так и на сервере.
Web Components использует императивный принцип — интерполяцию строк.
БЭМ использует декларативный подход, который позволяет гибко управлять шаблонизацией и избегать повторений.
Вместо импорта HTML — сборка
Web Components использует импорт HTML, который работает непосредственно в браузере. Для объединения HTML-файлов используется инструмент Vulcanize.
В БЭМ используется сборка. Для объединения файлов используются сборщики: ENB, Gulp.
Вместо Custom Elements — абстракция над DOM-деревом
В Web Components используются Custom Elements. Такой подход позволяет разместить на одном DOM-узле только один компонент.
В БЭМ используется БЭМ-дерево. Такой подход позволяет размещать на одном DOM-узле несколько компонентов (БЭМ-сущностей).
Подробнее читайте в разделе про миксы.
Полезен ли БЭМ в маленьких проектах?
Методология БЭМ предоставляет правила организации веб-проектов, независимо от их размера или количества разработчиков в команде. Даже если в вашей команде два человека и вы верстаете одностраничные сайты, БЭМ позволяет:
Повторно использовать верстку
Небольшие однотипные проекты могут иметь похожую структуру. Например, посадочные страницы (landing) — разные снаружи, одинаковые внутри. Для их создания можно использовать готовые шаблоны.
В пределах одной страницы используются одинаковые блоки: несколько кнопок, выпадающих списков или меню. Их можно взять из готовой библиотеки или реализовать свою библиотеку и использовать во всех проектах.
Быстро прототипировать верстку
Прототип сайта создается из блоков. Вместо верстки в БЭМ-проекте вы сразу проектируете интерфейс из готовых блоков.
Ускорить разработку
Уровни переопределения позволяют подключать библиотеки и доопределять блоки, не зависеть от обновлений библиотеки.
БЭМ-проект можно быстро начать с шаблонного проекта project-stub или bem-express.
Не зависеть от конкретного разработчика
Одинаковая структура всех проектов, одни правила организации кода, изолированные блоки облегчают передачу кода между разработчиками.
Ускорить рефакторинг
БЭМ-проект устроен таким образом, что изменения в одном блоке можно применить ко всем блокам в проекте. При этом нет необходимости знать все возможные случаи использования этого блока.
Система именования БЭМ-сущностей позволяет вложить смысл в имена и сделать их максимально информативными для разработчика, то есть писать самодокументируемый код.
Ускорить и упростить смену дизайна за счет уровней переопределения.
Минифицировать CSS/JS даже в одностраничном проекте.
В чем разница между БЭМ и Bootstrap?
Bootstrap — это свободный набор сверстанных блоков для создания сайтов и веб-приложений.
БЭМ — это методология, позволяющая:
создавать архитектуру проекта;
разрабатывать веб-приложения независимыми блоками;
упрощать поддержку проектов.
Также существует ряд библиотек с открытым исходным кодом:
bem-components — библиотека блоков, содержащая контролы форм и другие базовые компоненты веб-интерфейса;
bem-core — библиотека блоков, предоставляющая специализированный JavaScript-фреймворк для веб-разработки.
bem-history — БЭМ-обертка над History API.
Когда создавать блок, когда — элемент?
Методология БЭМ не устанавливает строгих правил создания блоков и элементов. Многое зависит от конкретных реализаций и личных предпочтений разработчика. Выбирайте то, что подходит именно вам, учитывая рекомендации.
Как изменить внешний вид блока?
Внешний вид блока можно изменить при помощи модификаторов или миксов.
Используйте модификаторы
Если существует вероятность переиспользовать блок в данном оформлении.
Используйте миксы
Если блок имеет специфичное оформление только для данного окружения и не будет переиспользован на проекте.
Подробнее про применение миксов и модификаторов читайте в разделе Когда создавать модификатор, когда — микс?.
Зачем в именах модификаторов и элементов указывать имя блока?
Имя блока в именах модификаторов и элементов:
Обеспечивает пространство имен.
Это позволяет ограничить влияние элементов и модификаторов одного блока на другой.
Пример
<div>...</div> <div>...</div>
Позволяет использовать миксы.
При использовании миксов необходимо явно указывать пространство имен для модификаторов, чтобы было ясно к какой из сущностей на данном DOM-узле относится модификатор.
Пример
<div>...</div>
Облегчает поиск в коде.
Уникальные имена облегчают поиск сущностей в коде и файловой структуре.
Зачем создавать отдельные директории и файлы для каждого блока и технологии?
Для удобства разработки и поддержки проекта файловую структуру БЭМ-проекта разделяют на вложенные директории и файлы.
Вы можете придерживаться рекомендуемой структуры проекта или использовать любую альтернативную:
Наследуют ли элементы блока его CSS-свойства?
Да. Механизм наследования CSS-свойств в БЭМ ничем не отличается от привычного наследования.
Чтобы одинаково оформить все элементы блока, целесообразно задать CSS-правила непосредственно блоку.
Чтобы оформить элементы по-разному, CSS-правила определяют непосредственно для каждого элемента. Возникших при этом повторов в результирующем коде можно избежать с помощью CSS-оптимизатора.
Почему не стоит создавать блоки-обертки?
Абстрактные обертки не имеют никакого смысла, так как задачи, которые они решают, реализуются с помощью миксов и дополнительных элементов блока.
Подробнее читайте в разделе HTML по БЭМ.
Почему не стоит создавать элементы элементов (block__elem1__elem2)?
Наличие элементов элементов ограничивает возможность изменять внутреннюю структуру блока. Элементы нельзя поменять местами, удалить или добавить без корректировки существующего кода.
Подробнее читайте в разделе Быстрый старт.
Когда создавать модификатор, когда — микс?
Создавайте модификатор
Если нужная вам реализация может использоваться повторно и не зависит от реализации других компонентов страницы. Например, блок select
имеет модификаторы: hovered, pressed, disabled, focused, opened.
Создавайте микс
Если нужная вам реализация требуется только для данного окружения и в данном виде точно не будет переиспользована на проекте.
Например, в большинстве случаев создается микс, если:
реализуется определенная бизнес-логика проекта;
задается внешняя геометрия для данного окружения.
Когда создавать булевый модификатор, когда — модификатор «ключ-значение»?
Создавайте булевый модификатор
Если важно только наличие или отсутствие модификатора у блока, а его значение несущественно. Например, модификатор, описывающий состояние «отключен»: disabled
.
Пример
<div>...</div>
Создавайте модификатор вида «ключ-значение»
Если состояний у блока может быть несколько. Например, для описания размеров блока можно использовать модификатор size
с допустимыми значениями s
, m
и l
.
Пример
<div>...</div> <div>...</div>
Как выбрать имя модификатора?
Выбирайте имена модификаторов, опираясь на семантику, а не на описываемые им CSS-свойства.
Пример
<button>...</button> <button>...</button>
Имя модификатора button_background_yellow
неудачное, потому что:
При изменении фона с желтого (
yellow
), например, на красный (red
) придется менять не только CSS-код, но и название селектора, шаблоны и, вполне вероятно, JavaScript-код.При добавлении других CSS-свойств, например,
border
,line-height
, имя модификатора перестанет соответствовать его содержанию.
Как сделать глобальные модификаторы для блоков?
В БЭМ отсутствует понятие глобальных модификаторов, так как имя любого модификатора содержит имя блока или элемента.
Если требуется вынести CSS-свойство за пределы одного блока и применять его к разным БЭМ-сущностям в проекте, необходимо создавать отдельный блок, реализованный в технологии CSS. После чего совместить реализацию разных блоков с помощью миксов.
Подробнее читайте в разделе Стилизация групп блоков.
Почему нельзя писать имя модификатора блока в имени элемента (block_mod__elem)?
Элемент — составная часть блока, а не модификатора блока. Таким образом, только имя блока может задавать пространство имен для элементов.
Это важно, потому что:
Блок может иметь много модификаторов.
Пример
<div> <div>...</div> </div>
Модификатор определяет состояние блока/элемента, которое может быть изменено во время выполнения скрипта JavaScript.
Как адаптировать сайт к различным устройствам?
Существует несколько способов изменять разметку страницы на основе ширины окна браузера:
используя Media Queries;
переключая модификаторы.
В обоих случаях необходимо определить контрольные точки (breakpoints), условия, при которых раскладка сайта меняется с одной на другую.
Media Queries
Файловая структура:
common.blocks/ button/ button.css # CSS-реализация кнопки
CSS-реализация:
@media (max-width: 767px) { .button { left: 0; } } @media (max-width: 479px) { .button { right: 0; } }
Примечание Имена блоков должны быть достаточно общими, для того чтобы его можно было использовать более чем с одной целью. Не стоит называть блок
sidebar-left
, если при изменении ширины экрана, его позиция изменится наright
.
Переключение модификатора
Файловая структура:
common.blocks/ button/ _position/ button_position_left.css button_position_right.css button.js # JS-реализация кнопки
button_position_left.css:
.button_position_left { left: 0; }
button_position_right.css:
.button_position_right { right: 0; }
Изменение CSS-классов на DOM-узле происходит при помощи JavaScript.
Подробнее читайте в разделе Переключение модификаторов.
Можно ли совмещать теги и классы в селекторе?
Совмещение тега и класса в селекторе повышает специфичность CSS-правил. Методология БЭМ не рекомендует совмещать теги и классы в селекторе.
Подробнее читайте в разделе Совмещение тега и класса в селекторе.
Можно ли использовать вложенные селекторы?
Вложенные селекторы увеличивают связанность кода и делают его повторное использование невозможным. Методология БЭМ допускает использование таких селекторов, но рекомендует свести их к минимуму.
Подробнее читайте в разделе Вложенные селекторы.
Можно ли использовать комбинированные селекторы?
Комбинированные селекторы имеют более высокую специфичность CSS-правил, чем одиночные. Успешность переопределения таких селекторов сильно привязана к порядку их объявления. Методология БЭМ не рекомендует использовать комбинированные селекторы.
Подробнее читайте в разделе Комбинированные селекторы.
Можно ли использовать селекторы по пользовательским тегам?
В HTML блоки могут выражаться с помощью пользовательских HTML-элементов (Custom Elements) с целью:
улучшить структуру веб-страницы и добавить смысловое значение заключенному в них содержимому;
использовать селекторы по пользовательским тегам вместо селекторов по классам;
связать с HTML-элементом дополнительные данные, с которыми потом будет работать JavaScript.
Методология БЭМ за улучшение семантики веб-страниц, но не рекомендует отказываться от селекторов по классам в пользу пользовательских тегов. В случае такой замены классы можно будет использовать только для модификаторов.
Пример
HTML-реализация:
<icon-twitter>...</icon-twitter>
CSS-реализация:
icon-twitter {} .icon_social_twitter {}
В таком подходе существует ряд ограничений:
невозможно использовать миксы;
не любой блок можно выразить пользовательским HTML-элементом. Например, для всех ссылок необходим тег
<a>
, а для полей —<input>
.
Почему не стоит делать общий сброс стилей (reset)?
На блоки не должны влиять CSS-правила, созданные для всей страницы. Это нарушает их независимость и затрудняет повторное использование.
Общий сброс стилей по сути реализуется с помощью глобальных CSS-правил, которые в большинстве случаев пишутся к селекторам на тег, что нежелательно делать в БЭМ-проекте.
Почему не стоит писать block_mod вместо block block_mod?
Если оставить только класс модификатора без указания класса самого блока/элемента, то все базовые CSS-свойства блока/элемента необходимо будет определить в модификаторе.
Модификатор определяет состояние блока/элемента, которое может быть изменено во время выполнения скрипта JavaScript. Таким образом, копировать базовые CSS-свойства блока придется во все его модификаторы.
Пример
<div> <div>...</div> </div>
Примечание. Совмещение нескольких модификаторов на одном и том же DOM-узле приведет к дублированию кода, реализующего базовую функциональность (логику и стили) блока.
В каких случаях следует создавать вспомогательные блоки?
Методология БЭМ не устанавливает строгих правил создания блоков-хелперов. Многое зависит от конкретных реализаций и личных предпочтений разработчика. Если такой блок необходим, то можно воспользоваться миксом.
Примером вспомогательного блока в bem-core может служить блок clearfix
, а в bem-components — z-index-group
.
Зачем внешнюю геометрию и позиционирование задавать через родительский блок?
Чтобы компонент оставался независимым, CSS-свойства, которые помешают его переиспользовать в другом окружении (например, margin
и position
), задают через родительский блок.
Подробнее читайте в разделе Внешняя геометрия и позиционирование
Зачем нужен i-bem.js, если есть jQuery?
i-bem.js не предназначен для замены фреймворка общего назначения, такого как jQuery.
i-bem.js
позволяет:
разрабатывать веб-интерфейс в терминах блоков, элементов, модификаторов;
интегрировать JavaScript-код с шаблонами и CSS-правилами в стиле БЭМ;
описывать логику работы блока как набор состояний.
Как работает позиционирование в 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 и научиться верстать? Посмотрите еще серию бесплатных видео по резиновой верстке сайта и бесплатный курс по основам адаптивной верстки. Эти материалы помогут вам продвинуться вперед гораздо быстрее:
Понравился материал и хотите отблагодарить?
Просто поделитесь с друзьями и коллегами!
Смотрите также:
Наверх
Как осуществить с помощью flexbox перенос на новую строку: позиционирование элементов
От автора: вот проблема: если вы хотите создать макет с несколькими строками элементов, как вы можете контролировать во flexbox перенос элементов на новую строку?
Предположим, вы хотите создать макет, который выглядит примерно так, с чередующимися строками из трех элементов и одним элементом на всю ширину:
Распространенным способом управления позиционированием и размером flex-элементов является использование width или flex-basic; если мы установим для четвертого элемента width 100%, он будет расположен в отдельной строке. Но что, если мы не хотим или не можем установить ширину отдельных элементов? Или есть ли способ просто указать flexbox разрыв строки в определенных точках?
Нет никакого свойства, которое мы могли бы установить для flex, чтобы оно переносило элементы на новую строку, но мы можем вставить перенос строки (вы можете представить это, как br) между двумя flex-элементами для достижения чего-то похожего:
Практический курс по верстке адаптивного сайта с нуля!
Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3
Узнать подробнее/* Вставка разрыва строки между двумя flex-элементами заставит * flex-элемент, который расположен после него переноситься на новую строку */ .break { flex-basis: 100%; height: 0; }
/* Вставка разрыва строки между двумя flex-элементами заставит * flex-элемент, который расположен после него переноситься на новую строку */ .break { flex-basis: 100%; height: 0; } |
<div> <div></div> <div></div> <!— break —> <div></div> </div>
<div> <div></div> <div></div> <!— break —> <div></div> </div> |
Давайте рассмотрим некоторые сценарии, когда вы, возможно, захотите использовать это, а также некоторые интересные методы компоновки, которые позволяет нам это использовать.
Обратите внимание , что все примеры кода ниже, требуют и предполагают, что у вас есть контейнер с display: flex и flex-wrap: wrap и flex-элементы добавляются в этот контейнер:
.container { display: flex; flex-wrap: wrap; }
.container { display: flex; flex-wrap: wrap; } |
<div> <div></div> <div></div> <div></div> … </div>
<div> <div></div> <div></div> <div></div> … </div> |
Вставка элемента разрыва
Использование элемента для перехода к новой строке flexbox дает интересный эффект: мы можем пропустить указание ширины любого элемента в макете и полностью полагаться на разрывы строк для определения потока сетки.
Давайте начнем с простого примера. Скажем, у нас есть два элемента, отображаемые рядом (они будут растягиваться с помощью flex-grow: 1, и для них не определены ни width, ни flex-basis):
Мы можем вставить элемент разрыва строки между элементами, чтобы они оба заняли 100% доступного пространства:
<div>…</div> <div></div> <!— перенос на новую строку —> <div>…</div>
<div>…</div> <div></div> <!— перенос на новую строку —> <div>…</div> |
Это создает макет с двумя вертикальными элементами полной ширины (я добавил границу к элементу .break, чтобы проиллюстрировать его положение и поведение):
Как это работает? Так как мы указали, что .break должен занимать 100% ширины контейнера (потому что мы установили flex-basis: 100%), flex-элемент переноса должен размещаться в собственном ряду, чтобы достигнуть этого. Он не может размещаться в одном ряду с первым элементом, поэтому перейдет к новой строке, в результате чего первый элемент останется один в одной строке. Первый элемент будет растягиваться, чтобы заполнить оставшееся пространство (так как мы установили flex-grow: 1). Та же логика применима ко второму элементу.
Мы можем использовать эту технику для компоновки макета, описанного в начале статьи, разбивая последовательность до и после каждого четвертого элемента:
<div>…</div> <div>…</div> <div>…</div> <div></div> <!— разрыв —> <div>…</div> <div></div> <!— разрыв —> <div>…</div> <div>…</div> <div>…</div>
<div>…</div> <div>…</div> <div>…</div> <div></div> <!— разрыв —> <div>…</div> <div></div> <!— разрыв —> <div>…</div> <div>…</div> <div>…</div> |
Это создаст нужный макет. По сути, элемент не будет переноситься на новую строку, если мы не вставим элемент разрыва строки:
Опять же, нам не нужно было указывать ширину ни для одного из этих элементов. Тот же самый метод будет работать для столбцов, если у нас есть гибкий контейнер с flex-direction: column, и установлено значение width 0 (вместо height) для элемента разрыва строки:
Практический курс по верстке адаптивного сайта с нуля!
Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3
Узнать подробнее/* Используем столбец разрыва для переноса в новый столбец */ .break-column { flex-basis: 100%; width: 0; }
/* Используем столбец разрыва для переноса в новый столбец */ .break-column { flex-basis: 100%; width: 0; } |
Такой подход с использованием элементов разрыва для определения макета добавляет некоторое раздутие и шум в HTML, но он может быть мощным инструментом при правильном использовании. Мы можем, например, использовать его для верстки макета кладки с помощью чистого CSS и динамически размещать разрывы с помощью свойства order. Мы также можем перейти к новой строке, не изменяя ширину какого-либо элемента содержимого, и мы можем полагаться исключительно на распределение пространства в макете сетки с помощью flex-grow.
Предположим, что мы хотим создать этот макет:
И предположим, что мы хотим сделать это, задав разные значения flex-grow для распределения пространства (вместо использования flex-basis или width, которые вам придется пересчитывать, когда вы добавляете или удаляете элементы):
.item { flex-grow: 1; } .item-wide { flex-grow: 3; }
.item { flex-grow: 1; } .item-wide { flex-grow: 3; } |
<div></div> <div></div> <div></div>
<div></div> <div></div> <div></div> |
Если затем мы хотим добавить еще одну строку элементов ниже этой:
Мы не сможем сделать это, не устанавливая flex-basis или width, по крайней мере, для некоторых элементов (или не создавая вложенный макет flexbox с одним flex-элементом для каждой строки). Если все элементы имеют разные значения flex-grow, и ничто не заставляет их переноситься на новую строку, они все просто втиснутся в одну строку:
Неплохо. Однако, если мы вставим элемент разрыва строки, мы можем построить этот макет, распределяя все пространство с помощью flex-grow:
.item { flex-grow: 1; } .item-wide { flex-grow: 3; }
.item { flex-grow: 1; } .item-wide { flex-grow: 3; } |
<div></div> <div></div> <div></div> <div></div> <!— разрыв —> <div></div> <div></div>
<div></div> <div></div> <div></div> <div></div> <!— разрыв —> <div></div> <div></div> |
Это задает нужный макет, со всеми размерами, определенными пропорционально через flex-grow:
И если будет сценарий, когда нам нужно пять элементов в первой строке, нам не нужно менять какой-либо CSS-код, чтобы это заработало, мы можем просто добавить эти элементы до разрыва строки:
<div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <!— разрыв —> <div></div> <div></div>
<div></div> <div></div> <div></div> <div></div> <div></div> <div></div> <!— разрыв —> <div></div> <div></div> |
Все, что вам нужно добавить в CSS, чтобы использовать элементы разрыва строки — это эти два класса (единственное различие между этими двумя классами состоит в том, что для width (а не для height) необходимо установить 0, чтобы элемент разрывал столбец при использовании в макете столбцов):
/* Использование разрыва строки между двумя flex-элементами заставит * flex-элемент, который расположен после него, перенестись в новую строку */ .break { flex-basis: 100%; height: 0; } /* Используем разрыв столбца, чтобы перенести элемент в новый столбец */ .break-column { flex-basis: 100%; width: 0; }
/* Использование разрыва строки между двумя flex-элементами заставит * flex-элемент, который расположен после него, перенестись в новую строку */ .break { flex-basis: 100%; height: 0; }
/* Используем разрыв столбца, чтобы перенести элемент в новый столбец */ .break-column { flex-basis: 100%; width: 0; } |
Вы, безусловно, может достичь того же или подобного эффекта с помощью вложенных flexbox, когда для каждого ряда будет задан отдельный flexbox, но во многих случаях простое использование flex-basis, width или контента в пределах flex-элементов, вероятно, будет предпочтительным способ управления потоком элементов в макете flexbox. Вставка элементов разрыва является доступной и простой в использовании, она работает, и данная техника обладает некоторыми уникальными характеристиками, которые могут вам пригодиться.
Автор: Tobias Bjerrome Ahlin
Источник: //tobiasahlin.com
Редакция: Команда webformyself.
Практический курс по верстке адаптивного сайта с нуля!
Изучите курс и узнайте, как верстать современные сайты на HTML5 и CSS3
Узнать подробнееPSD to HTML
Практика верстки сайта на CSS Grid с нуля
СмотретьКак прижать элемент к низу или верху родительского элемента — Site on!
Заметка: активирована адаптивная версия сайта, которая автоматически подстраивается под небольшой размер Вашего браузера и скрывает некоторые детали сайта для удобства чтения. Приятного просмотра!
06.08.2013
Здравствуйте! В сегодняшней короткой и сугубо практической статье я расскажу, как прижать, к примеру, div к низу другого div. Всё дело в том, что по одноименному запросу в своё время я не смог найти нужных мне ответов, поэтому сейчас я расскажу вам обо всех возможных способах сделать это.
Допустим, у нас есть 2 элемента на странице, неважно какие именно, для примера возьмём 2 div. Один из них будет вложен в другой, причём высота родителя будет больше высоты ребёнка:
<style> #parent{ background:black; height:300px; } #child{ background:red; height:100px; width:100px; } </style> <div> <div>Текст дочернего элемента</div> </div>
Для красоты и наглядности я сделал дочерний элемент квадратным:
Способ №1. Абсолютное позиционирование
Используем абсолютное позиционирование и при этом не забываем, что родительский элемент обязательно должен иметь позицию relative:
<style> #parent{ position:relative; /* добавили */ background:black; height:300px; } #child{ position:absolute; /* добавили */ bottom:0; /* добавили */ background:red; height:100px; width:100px; } </style> <div> <div>Текст дочернего элемента</div> </div>
Результат:
Плюсы:
Минусы:
Это значит что в таком случае:
<style> #parent{ background:black; height:300px; } #child,#child2,#child3{ display:inline-block; /* Сделали все div в одну строку */ height:100px; width:100px; } #child{ background:red; } #child2{ background:yellow; } #child3{ background:green; } </style> <div> <div>Текст дочернего элемента 1</div> <div>Текст дочернего элемента 2</div> <div>Текст дочернего элемента 3</div> </div>
Результат:
После проделанного выше способа получиться следующее:
Все элементы легли друг на друга, так как они не понимают, что существуют другие элементы, кроме них самих. В результате последний div (зелёный) оказался выше всех, в то время как первый (красный) ниже всех.
Конечно, кто-то может поспорить и сказать, что мы можем выставить у каждого div разную велечину left, например так:
<style> #parent{ position:relative; /* добавили */ background:black; height:300px; } #child,#child2,#child3{ position:absolute; /* добавили */ bottom:0; /* добавили */ height:100px; width:100px; } #child{ left:0; /* добавили */ background:red; } #child2{ left:110px; /* добавили */ background:yellow; } #child3{ left:220px; /* добавили */ background:green; } </style> <div> <div>Текст дочернего элемента 1</div> <div>Текст дочернего элемента 2</div> <div>Текст дочернего элемента 3</div> </div>
Результат:
Вроде всё отлично, зачем же нам делать как-то по-другому? Во-первых, как я уже говорил, для других элементов на странице наших абсолютно позиционированных блоков с текстом просто не существует, это может поломать вашу вёрстку.
Но это ерунда, куда важнее универсальность и рациональность. Поясняю, пользуясь способом №1 мы должны:
Способ №2. Вертикальное выравнивание
Этот способ подойдёт в том случае, если, к примеру, у родителя не задана высота, в то время как все дочерние элементы имеют разные высоты:
<style> #parent{ background:black; } #child,#child2,#child3{ display:inline-block; } #child{ background:red; height:300px; width:100px; } #child2{ background:yellow; height:100px; width:100px; } #child3{ background:green; height:200px; width:100px; } </style> <div> <div>Текст дочернего элемента 1</div> <div>Текст дочернего элемента 2</div> <div>Текст дочернего элемента 3</div> </div>
Результат:
Всё что нужно, чтобы это исправить – дописать всего лишь одну строчку:
<style> #parent{ background:black; } #child,#child2,#child3{ vertical-align:bottom; /* вот она */ display:inline-block; } #child{ background:red; height:300px; width:100px; } #child2{ background:yellow; height:100px; width:100px; } #child3{ background:green; height:200px; width:100px; } </style> <div> <div>Текст дочернего элемента 1</div> <div>Текст дочернего элемента 2</div> <div>Текст дочернего элемента 3</div> </div>
Результат:
Заметки:
1) Для того, чтобы применить вертикальное выравнивание (vertical-align), элементы ни в коем случае не должны иметь свойство float.
2) В отличие от предыдущего способа, нам без разницы, какую позицию (relative, absolute и тд.) будет иметь родитель, поэтому её можно просто не писать, по умолчанию она static.
Как прижать элементы к верху родительского
Обратная ситуация. Допустим нам нужно прижать div к верху родительского элемента.
Такая необходимость может появиться, например, если у вас внутри дочерних элементов высота регулируется не в CSS, а объёмом текста:
<style> #parent{ background:black; } #child,#child2,#child3{ width:100px; display:inline-block; } #child{ background:red; } #child2{ background:yellow; } #child3{ background:green; } </style> <div> <div>Много, много текста, много текста, много текста, много текста, много текста, много текста, много текста, много текста, много текста. Текст дочернего элемента 1</div> <div>Мало текста, мало текста. Текст дочернего элемента 2</div> <div>Средне текста, средне текста, средне текста, средне текста, средне текста. Текст дочернего элемента 3</div> </div>
Результат:
Чтобы это исправить, и прижать все элементы к верху родительского, нам необходимо задать свойство vertical-align в значение top:
<style> #parent{ background:black; } #child,#child2,#child3{ vertical-align:top; /* top */ width:100px; display:inline-block; } #child{ background:red; } #child2{ background:yellow; } #child3{ background:green; } </style> <div> <div>Много, много текста, много текста, много текста, много текста, много текста, много текста, много текста, много текста, много текста. Текст дочернего элемента 1</div> <div>Мало текста, мало текста. Текст дочернего элемента 2</div> <div>Средне текста, средне текста, средне текста, средне текста, средне текста. Текст дочернего элемента 3</div> </div>
Результат:
Вот и всё, спасибо за внимание. На востоке Украины сегодня пасмурно, но, несмотря на это желаю всем только солнечной погоды в ваших делах, удачи!
Пожалуйста, оцените эту статью
Средняя оценка: 4.26 из 5 (проголосовало: 164)Статья оказалась вам полезной? Подпишитесь, чтобы не пропустить новые!
Вы можете помочь развитию проекта, сделав всего 1 клик:
Спасибо!BootStrap | Размещение элемента с помощью примеров
BootStrap | Позиционирование элемента с помощью примеров
Фреймворк начальной загрузки предоставляет нам серию классов, которые позволяют нам изменять положение элемента. Он предоставляет нам пять классов, которые являются общими по функциям со свойством CSS position. Кроме того, он предоставляет три дополнительных класса для управления положением элемента.
Общие классы :
- статическое положение: Работает так же, как position: static; свойство CSS.
Пример:
<
html
>
<
головка
>
52
<
style
>
h2.text-center {
цвет: зеленый;
}
дел.родительский {
высота: 100 пикселей;
ширина: 400 пикселей;
граница: сплошной черный 1 пиксель;
маржа: 0 авто;
}
p {
верх: 10 пикселей;
слева: 10 пикселей;
отступ: 2 пикселя;
граница: 1 пиксель сплошного синего цвета;
дисплей: inline-block;
фон: # E3F2FD;
}
стиль
>
<
название
> UT /
название
>
головка
>
<
корпус
>
div
class
=
«контейнер»
>
<
h2
class
=
«text-center»
> GeeksForGeeks
h2
>
<
div
class
=
«parent»
>
<
p
class
=
«position-static»
> position-static
p
>
дел
>
дел
>
52
/
корпус
>
html
>
Выход:
- относительное положение: Работает так же, как положение : относительное; свойство CSS.
Пример:
66<
html
>
<
головка
>
52
<
style
>
h2.text-center {
цвет: зеленый;
}
дел.родительский {
высота: 100 пикселей;
ширина: 400 пикселей;
граница: сплошной черный 1 пиксель;
маржа: 0 авто;
}
p {
верх: 10 пикселей;
слева: 10 пикселей;
отступ: 2 пикселя;
граница: 1 пиксель сплошного синего цвета;
дисплей: inline-block;
фон: # E3F2FD;
}
стиль
>
<
название
> UT /
титул
>
головка
>
<
корпус
>
9002
<
div
class
=
«контейнер»
>
<
h2
class
=
«text-center»
> GeeksForGeeks
h2
>
<
div
class
=
«родительский»
>
<
p
class
=
«относительное положение»
>
относительно положения
p
>
div
>
div
>
корпус
>
html
>
- абсолютное положение: Работает так же s позиция : абсолютная; свойство CSS.
Пример:
<
html
>
0
<
> головка
<
style
>
h2.text-center {
цвет: зеленый;
}
дел.родительский {
высота: 100 пикселей;
ширина: 400 пикселей;
граница: сплошной черный 1 пиксель;
маржа: 0 авто;
}
p {
верх: 10 пикселей;
справа: 10 пикселей;
отступ: 2 пикселя;
граница: 1 пиксель сплошного синего цвета;
дисплей: inline-block;
фон: # E3F2FD;
}
стиль
>
<
название
> UT /
название
>
головка
>
<
корпус
>
<
div
class
=
«контейнер»
>
<
h2
class
=
«text-center»
> GeeksForGeeks
h2
>
<
div
class
=
«родительская позиция относительно позиции»
>
<
p
class
=
«position-absolute»
>
абсолютное положение
p
>
div
>
div
>
корпус
>
html
>
- абсолютное положение: Работает так же s позиция : абсолютная; свойство CSS.
- фиксированное положение: It работает так же, как и позиция : фиксированная; свойство CSS.
Пример:
<
html
>
<
головка
>
52
<
style
>
h2.text-center {
цвет: зеленый;
}
дел.родительский {
высота: 100 пикселей;
ширина: 400 пикселей;
граница: сплошной черный 1 пиксель;
маржа: 0 авто;
}
p {
верх: 10 пикселей;
справа: 10 пикселей;
отступ: 2 пикселя;
граница: 1 пиксель сплошного синего цвета;
дисплей: inline-block;
фон: # E3F2FD;
}
стиль
>
<
название
> UT /
название
>
головка
>
<
корпус
>
<
div
class
=
«контейнер»
>
<
h2
class
=
«text-center»
> GeeksForGeeks
h2
>
<
div
class
=
«родительский»
>
<
p
class
=
«position-fixed»
> position- фиксированный
p
>
дел
>
дел
>
6
корпус
>
html
>
Выход:
- Положение липкое, как позиция : липкая; свойство CSS.
Пример:
652<
html
>
<
головка
>
52
<
style
>
h2.text-center {
цвет: зеленый;
}
дел.родительский {
высота: 100 пикселей;
ширина: 400 пикселей;
граница: сплошной черный 1 пиксель;
маржа: 0 авто;
}
p {
верх: 10 пикселей;
справа: 10 пикселей;
отступ: 2 пикселя;
граница: 1 пиксель сплошного синего цвета;
дисплей: inline-block;
фон: # E3F2FD;
}
style
>
<
title
> UT /
название
>
головка
>
<
корпус
>
div
class
=
«контейнер»
>
<
h2
class
=
«text-center»
> GeeksForGeeks
h2
>
<
div
class
=
"parent"
>
<
p
class
=
"position-sticky"
>
фиксированная позиция
p
>
div
>
div
>
корпус
>
html
>
003 Выход: 0003 0003 Фиксированная крышка
- Фиксированная крышка: Это делает элемент, который нужно закрепить в верхней части области просмотра, от края до края.
Пример:
<
html
>
<
головка
>
52
<
style
>
h2.text-center {
цвет: зеленый;
верхнее поле: 30 пикселей;
}
дел.родительский {
высота: 100 пикселей;
ширина: 400 пикселей;
граница: сплошной черный 1 пиксель;
маржа: 0 авто;
}
p {
выравнивание текста: по центру;
отступ: 2 пикселя;
граница: 1 пиксель сплошного синего цвета;
дисплей: inline-block;
фон: # E3F2FD;
}
style
>
<
title
> UT /
название
>
головка
>
<
корпус
>
div
class
=
«контейнер»
>
<
h2
class
=
«text-center»
> GeeksForGeeks
h2
>
<
div
class
=
"parent"
>
<
p
class
=
"fixed-top"
> fixed-top
p
>
div
>
div
>
корпус
>
html
>
Мощность:
Фиксированное дно
- Фиксированное дно
- Это заставляет элемент фиксироваться внизу окна просмотра, от края до края.
Пример:
<
html
>
<
головка
>
52
<
style
>
h2.text-center {
цвет: зеленый;
верхнее поле: 30 пикселей;
}
дел.родительский {
высота: 100 пикселей;
ширина: 400 пикселей;
граница: сплошной черный 1 пиксель;
маржа: 0 авто;
}
p {
выравнивание текста: по центру;
отступ: 2 пикселя;
граница: 1 пиксель сплошного синего цвета;
дисплей: inline-block;
фон: # E3F2FD;
/ * Переопределение свойства margin-bottom по умолчанию
для бутстрапа, чтобы он
идеально прилегал к низу * /
margin -низ: 1px! important;
}
style
>
<
title
> UT /
название
>
головка
>
<
корпус
>
<
div
class
=
«контейнер»
>
<
h2
class
=
«text-center»
> GeeksForGeeks
h2
>
<
div
класс
=
«родительский»
>
<
p
класс
=
«с фиксированным дном»
> фиксированный- снизу
p
>
div
>
div
>
63
корпус
>
html
>
Выход:
- Фиксированная крышка: Это делает элемент, который нужно закрепить в верхней части области просмотра, от края до края.
0007 sticky-top: Заставляет элемент фиксироваться вверху области просмотра, от края до края, после прокрутки pa st элемент.В противном случае он позиционируется как статический.
Пример:
52 |
Вывод:
Bootstrap 4 Position - примеры и руководство.Базовое и расширенное использование
Компиляция и настройка
Чтобы еще больше уменьшить вес пакета MDBootstrap, вы можете скомпилировать свой собственный пакет, содержащий только эти компоненты и функции, которые вам нужны.
Если вам нужна дополнительная помощь в компиляции пользовательского пакета, воспользуйтесь нашим руководством по компиляции и настройке.
Руководство по компиляции и настройкеКарта зависимостей файлов SCSS в MDBootstrap:
Легенда:
'->' означает 'требуется'
Все бесплатные и профессиональные файлы требуют файлов из каталога 'core'
'none' означает 'этот компонент не требует ничего, кроме файлов ядра'
Файл, завернутый в ``, означает, что этот файл делает базовый компонент красивее, но это не обязательно для правильной работы.
Все компоненты PRO требуют 'pro / _variables.scss 'файл
scss /
|
| - ядро /
| |
| | - бутстрап /
| | | - _functions.scss
| | | - _variables.scss
| |
| | - _colors.scss
| | - _global.scss
| | - _helpers.scss
| | - _masks.scss
| | - _mixins.scss
| | - _typography.scss
| | - _variables.scss
| | - _waves.scss
|
| - бесплатно /
| | - _animations-basic.scss -> нет
| | - _animations-extended.scss -> _animations-basic.scss
| | - _buttons.scss -> нет
| | - _cards.scss -> нет
| | - _dropdowns.scss -> нет
| | - _input-group.scss -> _forms.scss, _buttons.scss, _dropdowns.scss
| | - _navbars.scss -> нет
| | - _pagination.scss -> нет
| | - _badges.scss -> нет
| | - _modals.scss -> _buttons.scss, _forms.scss (PRO -> _tabs.scss)
| | - _carousels.scss ->
| | - _forms.scss -> нет
| | - _msc.scss -> нет
| | - _footers.scss нет (PRO :)
| | - _list-group.scss -> нет
| | - _tables.scss -> нет (PRO: _material-select.scss, pro / _forms.scss, _checkbox.scss, pro / _buttons.scss, pro / _cards.scss, _pagination.scss, pro / _msc.scss )
| | - _depreciated.scss
|
| - pro /
| |
| | - сборщик /
| | | - _default.scss -> нет
| | | - _default-time.scss -> _default.scss, free / _forms.scss, free / _buttons.scss, pro / _buttons.scss, free / _cards.scss
| | | - _default-date.scss -> _default.scss, бесплатно / _forms.scss
| |
| | - разделы /
| | | - _templates.scss -> _sidenav.scss
| | | - _social.scss -> бесплатно / _cards.scss, бесплатно / _forms.scss, бесплатно / _buttons.scss, pro / _buttons.scss,
| | | - _team.scss -> бесплатно / _buttons.scss, pro / _buttons.scss, free / _cards.scss, pro / _cards.scss
| | | - _testimonials.scss -> бесплатно / _carousels.scss, pro / _carousels.scss, бесплатно / _buttons.scss, pro / _buttons.scss
| | | - _magazine.scss -> _badges.scss
| | | - _pricing.scss -> бесплатно / _buttons.scss, pro / _buttons.scss
| | | - _contacts.scss -> бесплатно / _forms.scss, pro / _forms.scss, бесплатно / _buttons.scss, pro / _buttons.scss
| |
| | - _variables.scss
| | - _buttons.scss -> бесплатно / _buttons.scss, pro / _msc.scss, _checkbox.scss, _radio.scss
| | - _social-buttons.scss -> бесплатно / _buttons.scss, pro / _buttons.scss
| | - _tabs.scss -> _cards.scss
| | - _cards.scss -> бесплатно / _cards.scss
| | - _dropdowns.scss -> бесплатно / _dropdowns.scss, бесплатно / _buttons.scss
| | - _navbars.scss -> бесплатно / _navbars.scss (PRO :)
| | - _scrollspy.scss -> нет
| | - _lightbox.scss -> нет
| | - _chips.scss -> нет
| | - _msc.scss -> нет
| | - _forms.scss -> нет
| | - _radio.scss -> нет
| | - _checkbox.scss -> нет
| | - _material-select.scss -> нет
| | - _switch.scss -> нет
| | - _file-input.scss -> бесплатно / _forms.scss, бесплатно / _buttons.scss
| | - _range.scss -> нет
| | - _input-group.scss -> free / _input-group.scss и то же, что и свободная группа ввода, _checkbox.scss, _radio.scss
| | - _autocomplete.scss -> бесплатно / _forms.scss
| | - _accordion.scss -> pro / _animations.scss, бесплатно / _cards.scss
| | - _parallax.scss -> нет
| | - _sidenav.scss -> бесплатно / _forms.scss, pro / _animations.scss, разделы / _templates.scss
| | - _ecommerce.scss -> бесплатно / _cards.scss, pro / _cards.scss, бесплатно / _buttons.scss, pro / _buttons.scss, pro / _msc.scss
| | - _carousels.scss -> бесплатно / _carousels.scss, бесплатно / _cards.scss, бесплатно / _buttons.scss
| | - _steppers.scss -> бесплатно / _buttons.scss
| | - _blog.scss -> нет
| | - _toasts.scss -> бесплатно / _buttons.scss
| | - _animations.scss -> нет
| | - _charts.scss -> нет
| | - _progress.scss -> нет
| | - _scrollbar.scss -> нет
| | - _skins.scss -> нет
| | - _устарело.scss
|
`- _custom-skin.scss
`- _custom-styles.scss
`- _custom-variables.scss
`- mdb.scss
Карта зависимостей модулей JavaScript в MDBootstrap:
Легенда:
'->' означает 'требуется'
Все файлы требуют jQuery и bootstrap.js
js /
├── dist /
│ ├── buttons.js
│ ├── cards.js
│ ├── character-counter.js
│ ├── chip.js
│ ├── collapsible.js -> vendor / velocity.js
│ ├── раскрывающийся список.js -> Popper.js, jquery.easing.js
│ ├── file-input.js
│ ├── forms-free.js
│ ├── material-select.js -> dropdown.js
│ ├── mdb-autocomplete.js
│ ├── preloading.js
│ ├── range-input.js -> vendor / velocity.js
│ ├── scrolling-navbar.js
│ ├── sidenav.js -> vendor / velocity.js, vendor / hammer.js, vendor / jquery.hammer.js
│ └── smooth-scroll.js
├── _intro-mdb-pro.js
├── modules.js
├── src /
│ ├── buttons.js
│ ├── карты.js
│ ├── character-counter.js
│ ├── chip.js
│ ├── collapsible.js -> vendor / velocity.js
│ ├── dropdown.js -> Popper.js, jquery.easing.js
│ ├── file-input.js
│ ├── forms-free.js
│ ├── material-select.js -> dropdown.js
│ ├── mdb-autocomplete.js
│ ├── preloading.js
│ ├── range-input.js -> vendor / velocity.js
│ ├── scrolling-navbar.js
│ ├── sidenav.js -> vendor / velocity.js, vendor / hammer.js, vendor / jquery.hammer.js
│ └── smooth-scroll.js
└── продавец /
├── аддоны /
│ ├── datatables.js
│ └── datatables.min.js
├── chart.js
├── extended-modals.js
├── hammer.js
├── jarallax.js
├── jarallax-video.js -> vendor / jarallax.js
├── jquery.easing.js
├── jquery.easypiechart.js
├── jquery.hammer.js -> vendor / hammer.js
├── jquery.sticky.js
├── lightbox.js
├── picker-date.js -> vendor / picker.js
├── picker.js
├── picker-time.js -> vendor / picker.js
├── scrollbar.js
├── scrolling-navbar.js
├── toastr.js
├── velocity.js
├── waves.js
└── wow.js
Bootstrap Position - Учебники с расширенными примерами
- Утилиты
- Position
Используйте эти сокращенные утилиты для быстрой настройки положения элемента.
Значения положения
Доступны классы быстрого позиционирования, но они не являются адаптивными .
...
...
...
...
...
Адаптивная позиция
С Torus Kit вы можете использовать отзывчивую позицию служебных классов, определенных с .position-
для всех разрешений и .position-
для отдельных разрешений.
...
...
...
...
...
...
...
...
...
...
...
...
...
...
...
...
...
...
Расположение элементов
Простое расположение элементов с помощью утилит для позиционирования кромок.Формат: {свойство} - {позиция}
.
Где свойство - одно из:
-
верх
- для вертикальноговерхнее положение
-
начало
- для горизонтальноголевое положение
(в LTR) -
низ
- для вертикальногонижнее положение
-
конец
- для горизонтального положениясправа
(в LTR)
Где положение - одно из:
-
0
- для0
крайнее положение -
50
- для50%
позиции края -
100
- для100%
позиции края
(Вы можете добавить дополнительные значения позиции, добавив записи в переменную $ position-values
Sass map.)
Центрировать элементы
Кроме того, вы также можете центрировать элементы с помощью служебного класса преобразования .translate-middle
.
Этот класс применяет преобразования translateX (-50%)
и translateY (-50%)
к элементу, что в сочетании с утилитами позиционирования кромок позволяет вам полностью центрировать элемент.
Путем добавления .translate-middle-x
или .translate -middle-y
, элементы могут располагаться только в горизонтальном или вертикальном направлении.
Улучшенное положение
Torus Kit улучшает положение Bootstrap и обеспечивает больший контроль над Это.Используя data-tor-position
, вы можете определить позицию элемента с помощью семантических ключевых слов, таких как
для горизонтальной оси и
для вертикальной оси . Это значения по умолчанию:
Ключевое слово | Значение CSS | Преобразование |
---|---|---|
слева | слева: 0 | нет |
центр 25 | 50% translateX (-50%) | |
справа | справа: 0 | нет |
верхняя | верхняя: 0 | нет |
средний | вверху: 50% | translateY (-50%) |
внизу | внизу: 0 | нет |
Левый
В положение элемент слева, добавьте data-tor-position = "left
Центр
Чтобы разместить элемент по центру, добавьте data-tor-position = "center
Right
Чтобы разместить элемент справа, добавьте data-tor-position = "right
Пользовательское положение
Вы также можете определить пользовательскую позицию на основе значений с помощью data-tor-position = "
.
Адаптивная позиция
Torus Kit адаптивная пользовательская позиция Утилита позволяет вам устанавливать различные значения позиции в разных разрешениях! Это дает вам полный контроль над положением ваших элементов.Используйте data-tor-position = "
Улучшенные центральные элементы
Хотя Bootstrap позволяет центрировать элемент с помощью служебного класса .translate-middle
, он переводит элемент только на 50 % в ограниченных направлениях.Утилита Torus kit data-tor-push
дает вам больше контроля над преобразованием значения и направления перевода.
Эта утилита вытолкнет элемент из его исходных позиций с помощью translateX | translateY
. Также возможно установить собственное пользовательское значение перевода
Поскольку data-tor-push
использует функцию CSS translate
, ее невозможно комбинировать с пользовательскими эффектами.
Предопределенные значения
Имеются два предопределенных значения: 50 | 100
, которые можно использовать в сочетании с data-tor-push = "<вверх | вниз | влево | вправо> (<значение>)"
Вертикальное направление
Чтобы нажать элемент в вертикальном направлении, используйте data-tor-push = "
div> Горизонтальное направление
Чтобы нажать элемент в горизонтальном направлении, используйте data-tor-push = " (<50 | 100>)"
Пользовательские значения
Вы также можете установить пользовательское значение перевода push .
Адаптивные центральные элементы
data-tor-push
также реагируют, поэтому вы можете точно настроить положение для разных разрешений.
Примеры
Вот несколько реальных примеров этих классов:
Почта +99 непрочитанных сообщений Маркер Предупреждения непрочитанных сообщений
Вы можете использовать эти классы с существующими компонентами для создания новых.Помните, что вы можете расширить его функциональность, добавив записи в переменную $ position-values
.
CSS позиция собственности
Пример
Позиционируйте элемент
:
h3
{
позиция: абсолютная;
слева: 100 пикселей;
верх: 150 пикселей;
}
Попробуй сам " Дополнительные примеры "Попробуйте сами" ниже.
Определение и использование
Свойство position
определяет тип метода позиционирования, используемый для
элемент (статический, относительный, абсолютный, фиксированный или липкий).
Значение по умолчанию: статический Унаследовано: нет Анимируемый: нет. Прочитать про 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 {
position: static;
граница: сплошной синий 1px;
ширина: 300 пикселей;
высота: 100 пикселей;
} # child1 {
позиция:
абсолютный;
граница: сплошной красный 1px;
верх: 70 пикселей;
справа: 15 пикселей;
}
# parent2 {
положение: относительное;
граница: сплошной синий 1px;
ширина: 300 пикселей;
высота: 100 пикселей;
}
# child2 {
позиция: абсолютная;
граница: сплошной красный 1px;
верх: 70 пикселей;
справа: 15 пикселей;
}
Попробуй сам "
Связанные страницы
Учебник CSS: позиционирование CSS
Ссылка HTML DOM:
позиция собственности
html - Как с помощью начальной загрузки добиться абсолютного позиционирования в элементе, а не в родительском?
На этот вопрос уже есть ответы здесь :
Закрыт 1 год назад.
У меня проблемы с абсолютным позиционированием в элементе, а не в родительском элементе с начальной загрузкой.
Желаемое поведение должно быть линией 1px, проходящей через середину h4 (после других стилей «позади»). CSS взят из другой темы и работает там. Однако с рамкой начальной загрузки нижний предел : 50%;
находится на 50% пути вниз по содержащему элементу, который находится на расстоянии миль.
Это мой CSS
# боковая панель.название-виджета: после {
цвет фона: # 485729;
}
.widget-title: after {
позиция: абсолютная;
содержание: "";
низ: 50%;
слева: 0;
ширина: 100%;
высота: 1 пикс;
фон: прозрачный;
}
Это HTML-код, о котором идет речь
Итоговый результат должен выглядеть так:
--- Мой милый титул -----------
Вместо этого строка находится на полпути вниз по странице.
Мой милый титул
-----------------------------
Все строки для элементов h4 находятся в одном и том же месте. Это заставляет меня думать, что позиционирование составляет 50% родительского div, а не h4. Поскольку это работает с темой без начальной загрузки, я предполагаю, что бутстрап делает что-то достаточно другое, чтобы сбить меня с толку. Я не уверен, что именно.
Как добиться желаемого поведения?
html - отзывчивость Bootstrap 4 для элементов с абсолютным позиционированием
html - отзывчивость Bootstrap 4 для элементов с абсолютным позиционированием - qaru Присоединяйтесь к Stack Overflow , чтобы учиться, делиться знаниями и строить свою карьеру.
Спросил
Просмотрено
1к раз
Я хотел бы получить такой экран на своей веб-странице.Абсолютно позиционируемый элемент - контейнер желтого цвета. Я написал носитель для каждого пикселя, который не дает оптимальной скорости отклика. Есть ли в начальной загрузке 4 какой-либо класс, который мог бы позиционировать себя таким образом и сделать его отзывчивым на всех устройствах без необходимости явно писать медиа-запрос? Заранее спасибо.
Пример начальной загрузки
<стиль>
.образец{
положение: относительное;
}
.ml-lg-1 {
позиция: абсолютная;
верх: 25vh;
осталось: -37vw;
}
@media (min-width: 1340px) {
.ml-lg-1 {
позиция: абсолютная;
верх: 25vh;
слева: -34vw;
}
}
@media (min-width: 1050 пикселей) {
.ml-lg-1 {
позиция: абсолютная;
верх: 25vh;
слева: -36vw;
}
}
@media (min-width: 1100 пикселей) {
.ml-lg-1 {
позиция: абсолютная;
верх: 25vh;
слева: -34vw;
}
}
@media (min-width: 1200 пикселей) {
.ml-lg-1 {
позиция: абсолютная;
верх: 25vh;
осталось: -37vw;
}
}
@media (min-width: 1300px) {
.ml-lg-1 {
позиция: абсолютная;
верх: 25vh;
слева: -34vw;
}
}
@media (min-width: 1380 пикселей) {
.ml-lg-1 {
позиция: абсолютная;
верх: 25vh;
осталось: -31vw;
}
}
@media (min-width: 1705px) {
.ml-lg-1 {
позиция: абсолютная;
верх: 25vh;
осталось: -24vw;
}
}
Первый
Второй
В третьих
Test1
Создан 23 янв.
Лакшми 851111 бронзовых знаков
4 Дайте сверху
и слева
расстояние в %
.
.ml-lg-1 {
позиция: абсолютная;
верх: 25%;
осталось: -125%;
}
Надеюсь, вы этого ожидаете.
Пример начальной загрузки
<стиль>
.образец{
положение: относительное;
}
.ml-lg-1 {
позиция: абсолютная;
верх: 25%;
осталось: -125%;
}
Первый
Второй
В третьих
Test1
Создан 23 янв.
Амареш С МАмареш С М 2,7122 золотых знака99 серебряных знаков2323 бронзовых знака
1 Я добавил только две колонки, но вы можете поиграть с ними, и это даст вам направление.нет необходимости в абсолютном позиционировании.
Вы можете использовать сетку следующим образом:
1 из 2
2 из 2
1 из 3
2 из 3
3 из 3
1 из 2
2 из 2
вот css:
.строка {
фон: # f8f9fa;
маржа сверху: 0 пикселей;
}
.col- {
граница: сплошная 1px # 6c757d;
отступ: 10 пикселей;
}
.желтый{
цвет фона: желтый;
}
.красный{
цвет фона: красный;
}
.зеленый{
цвет фона: зеленый;
}
вот и скрипка
Создан 23 янв.
пиксельквадрат 73088 серебряных знаков1919 бронзовых знаков
2 lang-html
Stack Overflow лучше всего работает с включенным JavaScript Ваша конфиденциальность
Нажимая «Принять все файлы cookie», вы соглашаетесь с тем, что Stack Exchange может хранить файлы cookie на вашем устройстве и раскрывать информацию в соответствии с нашей Политикой в отношении файлов cookie.
Принимать все файлы cookie
Настроить параметры
Как использовать Position: Sticky для боковых панелей с чистым CSS и Bootstrap
Введение
Липкая боковая панель - это метод веб-дизайна, позволяющий удерживать боковую панель на экране, даже если пользователь прокрутил страницу за позицию, в которой она изначально отображалась.Это полезно для облегчения доступа к суб-навигации, выделения вашего контента на боковой панели при прокрутке пользователем и потенциально увеличения количества показов рекламы, кликов и просмотров страниц.
В прошлом эта функциональность часто выполнялась с помощью вычислений JavaScript для определения положения прокрутки и переключения позиции элемента с
на абсолютное
или фиксированное
.
В настоящее время спецификация W3C определила липкое позиционирование
, и многие современные браузеры уже приняли его.
В этом руководстве вы создадите веб-страницу с боковой панелью, которая использует позицию : липкая
и Bootstrap 4.
Предварительные требования
Эта демонстрация не требует настройки локальной среды. Вы можете следовать вместе с редактором кода и браузером по вашему выбору.
Для выполнения этого урока вам потребуется:
Шаг 1. Использование позиции
: липкая
Спецификация для использования позиции : липкий
требует, чтобы направление вроде верх
или низ
было указано со значением, отличным от авто
.
Пример класса CSS, использующего это свойство, выглядит следующим образом:
.sticky {
положение: липкое;
верх: 0;
}
Чтобы испытать позицию : липкий
, вы можете создать новый каталог проекта:
- mkdir position-sticky-example
И перейдите в этот каталог:
- cd position-sticky-example
Внутри этого каталога проекта создайте пример .html
со следующим кодом:
example.html
Пример закрепленной позиции
<стиль>
* {
размер коробки: рамка-рамка;
}
html,
тело {
маржа: 0;
отступ: 0;
}
.placeholder-example {
фон: бледно-лиловый;
высота: 100vh;
заполнение: 1em;
}
.sticky-example {
фон: васильковый;
заполнение: 1em;
}
.sticky {
положение: липкое;
верх: 0;
}
Липкий
Заполнитель
Этот код создает div
с прикрепленным классом
и еще один div
с классом заполнителя
, который является полной высотой области просмотра.
Откройте index.html
в своем веб-браузере и посмотрите, как position: sticky
ведет себя при прокрутке страницы вверх и вниз.
Проверка поддержки браузера и использование резервных вариантов
Прежде чем применять новое свойство CSS, вам следует изучить, насколько хорошо оно поддерживается различными браузерами. Если функция не поддерживается браузерами вашей целевой аудитории, она не может быть хорошим кандидатом для внедрения в ваш проект.
Одним из инструментов для проверки поддержки браузером является "Могу ли я использовать".На данный момент страница «Могу ли я использовать» для позиции : липкий
сообщает, что в Internet Explorer нет поддержки для позиции : липкий
. Есть поддержка современных версий Edge, Firefox, Chrome, Safari и Opera. И есть две отмеченные известные проблемы, когда определенные аспекты позиции : липкий
не работают должным образом в некоторых браузерах.
Разумным откатом к позиции : липкий
будет позиция: относительная
.Это не приведет к идентичной работе с браузером, но обеспечит, чтобы пользователи с неподдерживаемыми браузерами по-прежнему имели доступ к контенту в пределах элементов position: sticky
.
Вы также можете рассмотреть возможность использования префиксов поставщиков для свойств CSS, таких как position: -webkit-sticky
, для обращения к более старым версиям Safari и iOS Safari.
Переписанный липкий класс
с резервной поддержкой будет напоминать:
.sticky {
положение: относительное;
позиция: -webkit-sticky;
положение: липкое;
верх: 0;
}
Этот код использует то, как браузер игнорирует значения свойств, которые он не распознает, и использует только последнее допустимое значение.
На этом завершается краткое введение в позицию : липкое поведение
. Давайте посмотрим, как применить это к расширенному сценарию.
У желаемого макета будет боковая панель, которая будет располагаться рядом с длинным блоком содержимого. Вы можете добиться этого с помощью библиотеки Bootstrap 4.
Вот схема предполагаемой планировки:
Заголовок
занимает верхнюю часть страницы. Контент-раздел
занимает большую часть левой части экрана.В правой части экрана расположено несколько элементов боковой панели: контейнер 1
, контейнер 2
, контейнер 3
и контейнер №
.
Создайте новый файл index.html
и добавьте библиотеку Bootstrap 4:
index.html
Боковая панель с закрепленным положением
<ссылка
rel = "таблица стилей"
href = "https: // путь к стеку.bootstrapcdn.com/bootstrap/4.5.2/css/bootstrap.min.css "
целостность = "sha384-JcKb8q3iqJ61gNV9KGb8thSsNjpSL0n8PARn9HuZOnIxN0hoP + VmmDGMN5t9UJ0Z"
crossorigin = "анонимный"
/>
<стиль>
Для достижения желаемого макета содержимое вашего тела
должно будет принять структуру разметки Bootstrap:
index.html
<статья>
Объединение липких боковых панелей с помощью Bootstrap 4
Раздел содержимого
Контейнер 1
Эта разметка устанавливает раздел содержимого
, который растягивает ширину 7 столбцов, и раздел боковой панели, который растягивает ширину 5 столбцов.Это добавляет до 12 столбцов, что является сеткой по умолчанию в Bootstrap 4.
Наклеивание
липкой вершины
Bootstrap 4 также поставляется с служебным классом sticky-top
, который функционально совпадает с классом sticky
, который вы создали ранее.
Перед тем, как применить sticky-top
, добавьте несколько стилей, чтобы сделать содержимое и разделы боковой панели более визуально заметными:
index.html
<стиль>
.content-section {
фон: бледно-лиловый;
высота: 1000 пикселей;
мин-высота: 100vh;
заполнение: 1em;
}
.sidebar-section {
высота: 100%;
}
.sidebar-content {
фон: васильковый;
заполнение: 1em;
}
Этот код определяет background-color
, height
и padding
для содержимого и раздела боковой панели.
Примечание: Высота
, указанная здесь для раздела содержимого, является произвольной величиной для демонстрационных целей.Если у вас был достаточно большой контент, вы могли положиться на него, чтобы определить макет и удалить свойство height
.
При посещении index.html
в веб-браузере вы должны увидеть раздел содержимого и меньшую часть боковой панели.
Теперь добавьте класс sticky-top
к элементу боковой панели
:
index.html
Контейнер 1
При прокрутке страницы вниз боковая панель должна иметь «липкое» поведение.
Это, вероятно, будет наиболее частым запросом функции для большинства сценариев. Следующие шаги будут исследовать более творческие сценарии.
Шаг 3 - Экспериментирование с расширенными сценариями
В следующем разделе вы возьмете файл index.html
, который вы создали ранее, и исследуете добавление нескольких элементов, наложение элементов боковой панели и, наконец, удаление элементов боковой панели с экрана.
Эксперименты с липкой боковой панелью и несколькими элементами
Основываясь на примере, вы можете добавить дополнительные элементы на боковую панель:
Индекс.html
Контейнер 1
Контейнер 2
Контейнер 3
Контейнер 4
При посещении index.html
в веб-браузере вы должны увидеть раздел содержимого и несколько элементов боковой панели.
Если вы преобразуете раздел боковой панели в гибкий блок с элементами, расположенными в столбце
с промежутком между
, вы можете создать более визуально интересную боковую панель:
index.html
<стиль>
/ * ... * /
.sidebar-section {
дисплей: гибкий;
flex-direction: столбец;
justify-content: пробел между;
высота: 100%;
}
/ * ... * /
При посещении index.html
в своем веб-браузере вы должны увидеть раздел содержимого и несколько элементов боковой панели с пробелом между ними.При прокрутке вниз вы должны заметить, что элементы боковой панели прилипают к верхней части экрана.
Общая просьба к функции - держать все элементы боковой панели визуально «сложенными» на экране.
Это потребует знания высоты
каждого элемента боковой панели и смещения липкого верхнего значения
. Вместо значения по умолчанию top: 0
, предоставляемого классом sticky-top
, вы должны указать сумму высоты предыдущих элементов боковой панели.
Поскольку количество элементов боковой панели и их высота известны в этой демонстрации, вы можете применить смещение к каждому элементу боковой панели, используя nth-child
:
index.html
<стиль>
/ * ... * /
.sidebar-item: nth-child (2) {
верх: 3.5em;
}
.sidebar-item: nth-child (3) {
верх: 7em;
}
.sidebar-item: nth-child (4) {
верх: 10,5 эм;
}
/ * ... * /
При посещении index.html
в своем веб-браузере вы должны увидеть раздел содержимого и несколько элементов боковой панели с пробелом между ними.При прокрутке вниз вы должны наблюдать штабелирование элементов боковой панели.
Однако это ограничено сценарием, когда вы знаете, что ваша боковая панель содержит 4
элементов боковой панели, каждый из которых имеет высоту 3,5 em
. Любая дополнительная сложность будет подчеркивать ограничения Pure CSS, и ваше время может быть лучше приспособлено для решения JavaScript.
Продолжая развивать предыдущий пример, менее ограниченной альтернативой может быть «вытолкнуть» предыдущий элемент боковой панели с экрана.
Во-первых, вы должны удалить предыдущие эксперименты с nth-child
.
Эта новая конфигурация будет использовать свойство flex-grow
для .sidebar-item
:
index.html
<стиль>
/ * ... * /
.sidebar-item {
flex-grow: 1;
}
/ * ... * /
Теперь переместите класс sticky-top
из элемента sidebar-item
в элемент sidebar-content
:
Индекс.html
Контейнер 1
Контейнер 2
Контейнер 3
Контейнер 4
При посещении index.html
в веб-браузере вы должны увидеть раздел содержимого и несколько элементов боковой панели.При прокрутке вниз вы должны наблюдать поведение «наложения», когда элементы боковой панели «выталкивают» предыдущие элементы боковой панели.
Примечание: В предыдущей версии этого руководства использовался подход « позиция: абсолютный
» из-за ограничений, возникающих при использовании display: flexbox
и position: sticky
в веб-браузерах в то время.
Этот пример CodePen отображает подход позиция: абсолютный
.
Однако во время этой редакции подход flexbox
предлагает большую гибкость и требует меньшего количества операций с различным количеством элементов боковой панели, высотой и смещением.
Можно провести дальнейшие эксперименты, отрегулировав ширину, высоту и смещения.
Заключение
В этом руководстве вы узнали о свойстве CSS position: sticky
и о том, как его можно использовать для боковых панелей в ваших макетах для веб-дизайна.
Оставить комментарий