Перейти к основному содержанию Перейти к навигации по документам
in English

Соотношения

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

О

Используйте помощник соотношения для управления соотношениями сторон внешнего контента, такого как <iframe>s, <embed>s, <video>s и <object>s. Эти помощники также могут использоваться для любого стандартного дочернего элемента HTML (например, a <div>или <img>). Стили применяются от родительского .ratioкласса непосредственно к дочернему.

Соотношения сторон объявляются в карте Sass и включаются в каждый класс через переменную CSS, что также позволяет настраивать соотношения сторон .

Совет! Вам не нужны frameborder="0"ваши <iframe>s, так как мы переопределяем это для вас в Reboot .

Пример

Оберните любую вставку, например <iframe>, в родительский элемент с .ratioклассом соотношения сторон и . Размер непосредственного дочернего элемента определяется автоматически благодаря нашему универсальному селектору .ratio > *.

<div class="ratio ratio-16x9">
  <iframe src="https://www.youtube.com/embed/zpOULjyy-n8?rel=0" title="YouTube video" allowfullscreen></iframe>
</div>

Соотношение сторон

Соотношения сторон можно настроить с помощью классов модификаторов. По умолчанию предоставляются следующие классы соотношений:

1x1
4x3
16x9
21x9
<div class="ratio ratio-1x1">
  <div>1x1</div>
</div>
<div class="ratio ratio-4x3">
  <div>4x3</div>
</div>
<div class="ratio ratio-16x9">
  <div>16x9</div>
</div>
<div class="ratio ratio-21x9">
  <div>21x9</div>
</div>

Пользовательские коэффициенты

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

Например, чтобы создать соотношение сторон 2x1, установите --bs-aspect-ratio: 50%для параметра .ratio.

2x1
<div class="ratio" style="--bs-aspect-ratio: 50%;">
  <div>2x1</div>
</div>

Эта переменная CSS упрощает изменение соотношения сторон между контрольными точками. Далее следует 4x3 для начала, но он меняется на пользовательский 2x1 в средней точке останова.

.ratio-4x3 {
  @include media-breakpoint-up(md) {
    --bs-aspect-ratio: 50%; // 2x1
  }
}
4х3, затем 2х1
<div class="ratio ratio-4x3">
  <div>4x3, then 2x1</div>
</div>

Карта Сасса

Внутри _variables.scssвы можете изменить пропорции, которые вы хотите использовать. Вот наша $ratio-aspect-ratiosкарта по умолчанию. Измените карту по своему усмотрению и перекомпилируйте свой Sass, чтобы использовать их.

$aspect-ratios: (
  "1x1": 100%,
  "4x3": calc(3 / 4 * 100%),
  "16x9": calc(9 / 16 * 100%),
  "21x9": calc(9 / 21 * 100%)
);