Skip to main content Skip to docs navigation

使用生成的伪元素使元素保持你选择的纵横比。 非常适合根据父对象的宽度响应处理视频或幻灯片嵌入。

On this page

关于

使用比率帮助器来管理外部内容的纵横比,如<iframe>'<embed><video><object>。 这些帮助程序也可以用于任何标准的HTML子元素(例如<div><img>)。 样式是从父类.ratio应用到直接子的。

纵横比在Sass映射中声明,并通过CSS变量包含在每个类中,这也允许自定义纵横比

Pro-Tip! 你不需要在<iframe>上使用 frameborder="0",因为我们在Reboot中为你覆盖了它。

实例

.ratio和纵横比类包装父元素中的任何嵌入,如<iframe>。 由于我们的通用选择器.ratio > *,直接子元素的大小会自动调整。

html
<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
html
<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>

自定义比率

每个.aratio-*类在选择器中都包含一个CSS自定义属性(或CSS变量)。 你可以覆盖这个CSS变量,通过一些快速的数学运算来动态创建自定义纵横比。

例如,要创建2x1的纵横比,请在.aratio上设置--bs-aspect-ratio: 50%

2x1
html
<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
  }
}
4x3, then 2x1
html
<div class="ratio ratio-4x3">
  <div>4x3, then 2x1</div>
</div>

Sass maps

_variables.scss中,你可以更改要使用的纵横比。 这是我们默认的$ratio-aspect-ratios map。 根据你的喜好修改地图,并重新编译Sass以使用它们。

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