跳到主要内容 跳到文档导航
Check
in English

比率

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

在本页面

关于

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

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

专家提示!您不需要 frameborder="0"在您 的 s 上,因为我们会在Reboot<iframe>中为您覆盖它 。

例子

使用和纵横比类将任何嵌入(如<iframe>)包装在父元素中。.ratio由于我们的通用选择器,直接子元素会自动调整大小.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>

自定义比率

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

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

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,然后是 2x1
html
<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%)
);