跳到主题内容 跳到文档导航栏

比例(Ratio)

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

关于

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

长宽比在Sass映射中声明,并通过CSS变量包含在每个类中,CSS变量还允许 自定义长宽比

专业提示! 您不需要在 <iframe> 上使用frameborder="0",因为我们会在重新启动时为您覆盖它。

示例

使用.ratio和长宽比类将任何嵌入(如<iframe>。由于我们的通用选择器,直接子元素的大小会自动调整 .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长宽比,请在.ratio 上设置 --aspect-ratio: 50%

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

这个CSS变量可以很容易地修改断点之间的长宽比。以下是4x3开始,但在中间断点处更改为自定义2x1。

.ratio-4x3 {
  @include media-breakpoint-up(md) {
    --aspect-ratio: 50%; // 2x1
  }
}
4x3, then 2x1
<div class="ratio ratio-4x3">
  <div>4x3, then 2x1</div>
</div>

Sass 映射

_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%)
);