Skip to main content Skip to docs navigation

Bootstrap 的卡片提供了一个具有多种变体和选项的灵活且可扩展的内容容器。

关于

卡片是一种灵活且可扩展的内容容器。它包括页眉和页脚选项、各种内容、上下文背景颜色和强大的显示选项。如果您熟悉 Bootstrap 3,卡片将取代我们的旧面板、井和缩略图。与这些组件类似的功能可用作卡片的修饰符类。

例子

卡片是用尽可能少的标记和样式构建的,但仍然设法提供大量的控制和定制。它们使用 flexbox 构建,可以轻松对齐并与其他 Bootstrap 组件很好地混合。默认情况下没有margin,因此请根据需要使用间距实用程序

下面是一个包含混合内容和固定宽度的基本卡片示例。卡片没有固定的起始宽度,因此它们自然会填满其父元素的整个宽度。这很容易通过我们的各种尺码选项进行定制。

PlaceholderImage cap
卡片名称

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

去一个地方
网页格式
<div class="card" style="width: 18rem;">
  <img src="..." class="card-img-top" alt="...">
  <div class="card-body">
    <h5 class="card-title">Card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
    <a href="#" class="btn btn-primary">Go somewhere</a>
  </div>
</div>

内容类型

卡片支持多种内容,包括图像、文本、列表组、链接等。以下是所支持内容的示例。

身体

卡片的构建块是.card-body. 只要您需要卡片中的填充部分,就可以使用它。

这是卡片正文中的一些文本。
网页格式
<div class="card">
  <div class="card-body">
    This is some text within a card body.
  </div>
</div>

卡片标题通过添加.card-title<h*>标签来使用。.card-link以同样的方式,通过添加到<a>标签来添加链接并将它们彼此相邻放置。

通过在标签中添加 a.card-subtitle来使用字幕。<h*>如果将.card-title.card-subtitle项目放在一个.card-body项目中,则卡片标题和副标题会很好地对齐。

卡片名称
卡片字幕

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

卡片链接 另一个链接
网页格式
<div class="card" style="width: 18rem;">
  <div class="card-body">
    <h5 class="card-title">Card title</h5>
    <h6 class="card-subtitle mb-2 text-muted">Card subtitle</h6>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
    <a href="#" class="card-link">Card link</a>
    <a href="#" class="card-link">Another link</a>
  </div>
</div>

图片

.card-img-top将图像放在卡片顶部。使用.card-text,可以将文本添加到卡片中。其中的文本.card-text也可以使用标准 HTML 标签设置样式。

PlaceholderImage cap

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

网页格式
<div class="card" style="width: 18rem;">
  <img src="..." class="card-img-top" alt="...">
  <div class="card-body">
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>

列出群组

使用刷新列表组在卡片中创建内容列表。

  • 一个物品
  • 第二项
  • 第三项
网页格式
<div class="card" style="width: 18rem;">
  <ul class="list-group list-group-flush">
    <li class="list-group-item">An item</li>
    <li class="list-group-item">A second item</li>
    <li class="list-group-item">A third item</li>
  </ul>
</div>
精选
  • 一个物品
  • 第二项
  • 第三项
网页格式
<div class="card" style="width: 18rem;">
  <div class="card-header">
    Featured
  </div>
  <ul class="list-group list-group-flush">
    <li class="list-group-item">An item</li>
    <li class="list-group-item">A second item</li>
    <li class="list-group-item">A third item</li>
  </ul>
</div>
  • 一个物品
  • 第二项
  • 第三项
网页格式
<div class="card" style="width: 18rem;">
  <ul class="list-group list-group-flush">
    <li class="list-group-item">An item</li>
    <li class="list-group-item">A second item</li>
    <li class="list-group-item">A third item</li>
  </ul>
  <div class="card-footer">
    Card footer
  </div>
</div>

厨房水槽

混合搭配多种内容类型来创建您需要的卡片,或者将所有内容都放入其中。下面显示的是图像样式、块、文本样式和列表组——所有这些都包裹在一个固定宽度的卡片中。

PlaceholderImage cap
卡片名称

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

  • 一个物品
  • 第二项
  • 第三项
网页格式
<div class="card" style="width: 18rem;">
  <img src="..." class="card-img-top" alt="...">
  <div class="card-body">
    <h5 class="card-title">Card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
  <ul class="list-group list-group-flush">
    <li class="list-group-item">An item</li>
    <li class="list-group-item">A second item</li>
    <li class="list-group-item">A third item</li>
  </ul>
  <div class="card-body">
    <a href="#" class="card-link">Card link</a>
    <a href="#" class="card-link">Another link</a>
  </div>
</div>

在卡片中添加可选的页眉和/或页脚。

精选
特殊职称待遇

将下面的支持文本作为附加内容的自然引导。

去一个地方
网页格式
<div class="card">
  <div class="card-header">
    Featured
  </div>
  <div class="card-body">
    <h5 class="card-title">Special title treatment</h5>
    <p class="card-text">With supporting text below as a natural lead-in to additional content.</p>
    <a href="#" class="btn btn-primary">Go somewhere</a>
  </div>
</div>

可以通过添加.card-header<h*>元素来设置卡片标题的样式。

精选
特殊职称待遇

将下面的支持文本作为附加内容的自然引导。

去一个地方
网页格式
<div class="card">
  <h5 class="card-header">Featured</h5>
  <div class="card-body">
    <h5 class="card-title">Special title treatment</h5>
    <p class="card-text">With supporting text below as a natural lead-in to additional content.</p>
    <a href="#" class="btn btn-primary">Go somewhere</a>
  </div>
</div>
引用

一个众所周知的引用,包含在 blockquote 元素中。

来源标题中的名人
网页格式
<div class="card">
  <div class="card-header">
    Quote
  </div>
  <div class="card-body">
    <blockquote class="blockquote mb-0">
      <p>A well-known quote, contained in a blockquote element.</p>
      <footer class="blockquote-footer">Someone famous in <cite title="Source Title">Source Title</cite></footer>
    </blockquote>
  </div>
</div>
精选
特殊职称待遇

将下面的支持文本作为附加内容的自然引导。

去一个地方
网页格式
<div class="card text-center">
  <div class="card-header">
    Featured
  </div>
  <div class="card-body">
    <h5 class="card-title">Special title treatment</h5>
    <p class="card-text">With supporting text below as a natural lead-in to additional content.</p>
    <a href="#" class="btn btn-primary">Go somewhere</a>
  </div>
  <div class="card-footer text-muted">
    2 days ago
  </div>
</div>

浆纱

卡片假定没有特定width的开始,因此除非另有说明,否则它们将是 100% 宽。您可以根据需要使用自定义 CSS、网格类、网格 Sass 混合宏或实用程序更改此设置。

使用网格标记

使用网格,根据需要将卡片包裹在列和行中。

特殊职称待遇

将下面的支持文本作为附加内容的自然引导。

去一个地方
特殊职称待遇

将下面的支持文本作为附加内容的自然引导。

去一个地方
网页格式
<div class="row">
  <div class="col-sm-6 mb-3 mb-sm-0">
    <div class="card">
      <div class="card-body">
        <h5 class="card-title">Special title treatment</h5>
        <p class="card-text">With supporting text below as a natural lead-in to additional content.</p>
        <a href="#" class="btn btn-primary">Go somewhere</a>
      </div>
    </div>
  </div>
  <div class="col-sm-6">
    <div class="card">
      <div class="card-body">
        <h5 class="card-title">Special title treatment</h5>
        <p class="card-text">With supporting text below as a natural lead-in to additional content.</p>
        <a href="#" class="btn btn-primary">Go somewhere</a>
      </div>
    </div>
  </div>
</div>

使用实用程序

使用我们为数不多的可用大小调整实用程序来快速设置卡片的宽度。

卡片名称

将下面的支持文本作为附加内容的自然引导。

按钮
卡片名称

将下面的支持文本作为附加内容的自然引导。

按钮
网页格式
<div class="card w-75 mb-3">
  <div class="card-body">
    <h5 class="card-title">Card title</h5>
    <p class="card-text">With supporting text below as a natural lead-in to additional content.</p>
    <a href="#" class="btn btn-primary">Button</a>
  </div>
</div>

<div class="card w-50">
  <div class="card-body">
    <h5 class="card-title">Card title</h5>
    <p class="card-text">With supporting text below as a natural lead-in to additional content.</p>
    <a href="#" class="btn btn-primary">Button</a>
  </div>
</div>

使用自定义 CSS

在您的样式表中使用自定义 CSS 或作为内联样式来设置宽度。

特殊职称待遇

将下面的支持文本作为附加内容的自然引导。

去一个地方
网页格式
<div class="card" style="width: 18rem;">
  <div class="card-body">
    <h5 class="card-title">Special title treatment</h5>
    <p class="card-text">With supporting text below as a natural lead-in to additional content.</p>
    <a href="#" class="btn btn-primary">Go somewhere</a>
  </div>
</div>

文本对齐

您可以使用我们的文本对齐类快速更改任何卡片的文本对齐方式——整体或特定部分。

特殊职称待遇

将下面的支持文本作为附加内容的自然引导。

去一个地方
特殊职称待遇

将下面的支持文本作为附加内容的自然引导。

去一个地方
特殊职称待遇

将下面的支持文本作为附加内容的自然引导。

去一个地方
网页格式
<div class="card mb-3" style="width: 18rem;">
  <div class="card-body">
    <h5 class="card-title">Special title treatment</h5>
    <p class="card-text">With supporting text below as a natural lead-in to additional content.</p>
    <a href="#" class="btn btn-primary">Go somewhere</a>
  </div>
</div>

<div class="card text-center mb-3" style="width: 18rem;">
  <div class="card-body">
    <h5 class="card-title">Special title treatment</h5>
    <p class="card-text">With supporting text below as a natural lead-in to additional content.</p>
    <a href="#" class="btn btn-primary">Go somewhere</a>
  </div>
</div>

<div class="card text-end" style="width: 18rem;">
  <div class="card-body">
    <h5 class="card-title">Special title treatment</h5>
    <p class="card-text">With supporting text below as a natural lead-in to additional content.</p>
    <a href="#" class="btn btn-primary">Go somewhere</a>
  </div>
</div>

使用 Bootstrap 的导航组件向卡片的标题(或块)添加一些导航。

特殊职称待遇

将下面的支持文本作为附加内容的自然引导。

去一个地方
网页格式
<div class="card text-center">
  <div class="card-header">
    <ul class="nav nav-tabs card-header-tabs">
      <li class="nav-item">
        <a class="nav-link active" aria-current="true" href="#">Active</a>
      </li>
      <li class="nav-item">
        <a class="nav-link" href="#">Link</a>
      </li>
      <li class="nav-item">
        <a class="nav-link disabled">Disabled</a>
      </li>
    </ul>
  </div>
  <div class="card-body">
    <h5 class="card-title">Special title treatment</h5>
    <p class="card-text">With supporting text below as a natural lead-in to additional content.</p>
    <a href="#" class="btn btn-primary">Go somewhere</a>
  </div>
</div>
特殊职称待遇

将下面的支持文本作为附加内容的自然引导。

去一个地方
网页格式
<div class="card text-center">
  <div class="card-header">
    <ul class="nav nav-pills card-header-pills">
      <li class="nav-item">
        <a class="nav-link active" href="#">Active</a>
      </li>
      <li class="nav-item">
        <a class="nav-link" href="#">Link</a>
      </li>
      <li class="nav-item">
        <a class="nav-link disabled">Disabled</a>
      </li>
    </ul>
  </div>
  <div class="card-body">
    <h5 class="card-title">Special title treatment</h5>
    <p class="card-text">With supporting text below as a natural lead-in to additional content.</p>
    <a href="#" class="btn btn-primary">Go somewhere</a>
  </div>
</div>

图片

卡片包括一些用于处理图像的选项。选择在卡片的两端附加“图像帽”,用卡片内容覆盖图像,或者简单地将图像嵌入卡片中。

图像上限

与页眉和页脚类似,卡片可以包括顶部和底部的“图像帽”——卡片顶部或底部的图像。

PlaceholderImage cap
卡片名称

这是一张更宽的卡片,下面有支持文本作为附加内容的自然引导。这个内容有点长。

最后更新于 3 分钟前

卡片名称

这是一张更宽的卡片,下面有支持文本作为附加内容的自然引导。这个内容有点长。

最后更新于 3 分钟前

PlaceholderImage cap
网页格式
<div class="card mb-3">
  <img src="..." class="card-img-top" alt="...">
  <div class="card-body">
    <h5 class="card-title">Card title</h5>
    <p class="card-text">This is a wider card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
    <p class="card-text"><small class="text-muted">Last updated 3 mins ago</small></p>
  </div>
</div>
<div class="card">
  <div class="card-body">
    <h5 class="card-title">Card title</h5>
    <p class="card-text">This is a wider card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
    <p class="card-text"><small class="text-muted">Last updated 3 mins ago</small></p>
  </div>
  <img src="..." class="card-img-bottom" alt="...">
</div>

图像叠加

将图像变成卡片背景并覆盖卡片的文本。根据图像的不同,您可能需要也可能不需要额外的样式或实用程序。

PlaceholderCard image
卡片名称

这是一张更宽的卡片,下面有支持文本作为附加内容的自然引导。这个内容有点长。

最后更新于 3 分钟前

网页格式
<div class="card text-bg-dark">
  <img src="..." class="card-img" alt="...">
  <div class="card-img-overlay">
    <h5 class="card-title">Card title</h5>
    <p class="card-text">This is a wider card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
    <p class="card-text"><small>Last updated 3 mins ago</small></p>
  </div>
</div>
请注意,内容不应大于图像的高度。如果内容比图像大,则内容将显示在图像之外。

水平的

结合使用网格和实用程序类,可以以移动友好且响应迅速的方式将卡片制作成水平的。在下面的示例中,我们删除了网格间距.g-0并使用.col-md-*类使卡片在md断点处水平。根据您的卡片内容,可能需要进一步调整。

PlaceholderImage
卡片名称

这是一张更宽的卡片,下面有支持文本作为附加内容的自然引导。这个内容有点长。

最后更新于 3 分钟前

网页格式
<div class="card mb-3" style="max-width: 540px;">
  <div class="row g-0">
    <div class="col-md-4">
      <img src="..." class="img-fluid rounded-start" alt="...">
    </div>
    <div class="col-md-8">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This is a wider card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
        <p class="card-text"><small class="text-muted">Last updated 3 mins ago</small></p>
      </div>
    </div>
  </div>
</div>

卡片样式

卡片包括用于自定义背景、边框和颜色的各种选项。

背景和颜色

添加于 v5.2.0

我们的助手一起设置background-color对比鲜明的前景。以前需要手动配对您选择的样式和实用程序,如果您愿意,您仍然可以使用它。color.text-bg-{color}.text-{color}.bg-{color}

标头
主卡标题

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

标头
副卡标题

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

标头
成功卡标题

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

标头
危险卡标题

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

标头
警告卡标题

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

标头
信息卡标题

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

标头
光卡标题

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

标头
暗卡称号

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

网页格式
<div class="card text-bg-primary mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body">
    <h5 class="card-title">Primary card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>
<div class="card text-bg-secondary mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body">
    <h5 class="card-title">Secondary card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>
<div class="card text-bg-success mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body">
    <h5 class="card-title">Success card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>
<div class="card text-bg-danger mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body">
    <h5 class="card-title">Danger card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>
<div class="card text-bg-warning mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body">
    <h5 class="card-title">Warning card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>
<div class="card text-bg-info mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body">
    <h5 class="card-title">Info card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>
<div class="card text-bg-light mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body">
    <h5 class="card-title">Light card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>
<div class="card text-bg-dark mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body">
    <h5 class="card-title">Dark card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>
向辅助技术传达意义

使用颜色来添加含义仅提供视觉指示,不会将其传达给辅助技术的用户——例如屏幕阅读器。确保用颜色表示的信息要么从内容本身(例如可见文本)中显而易见,要么通过其他方式包含在内,例如隐藏在.visually-hidden类中的附加文本。

边界

使用边框实用程序仅更改border-color卡片的。请注意,您可以将.text-{color}类放在父级.card或卡片内容的子集上,如下所示。

标头
主卡标题

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

标头
副卡标题

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

标头
成功卡标题

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

标头
危险卡标题

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

标头
警告卡标题

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

标头
信息卡标题

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

标头
光卡标题

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

标头
暗卡称号

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

网页格式
<div class="card border-primary mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body text-primary">
    <h5 class="card-title">Primary card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>
<div class="card border-secondary mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body text-secondary">
    <h5 class="card-title">Secondary card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>
<div class="card border-success mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body text-success">
    <h5 class="card-title">Success card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>
<div class="card border-danger mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body text-danger">
    <h5 class="card-title">Danger card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>
<div class="card border-warning mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body">
    <h5 class="card-title">Warning card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>
<div class="card border-info mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body">
    <h5 class="card-title">Info card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>
<div class="card border-light mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body">
    <h5 class="card-title">Light card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>
<div class="card border-dark mb-3" style="max-width: 18rem;">
  <div class="card-header">Header</div>
  <div class="card-body">
    <h5 class="card-title">Dark card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
</div>

Mixins 实用程序

您还可以根据需要更改卡片页眉和页脚的边框,甚至可以删除它们background-color.bg-transparent.

标头
成功卡标题

建立在卡片标题上并构成卡片内容主体的一些快速示例文本。

网页格式
<div class="card border-success mb-3" style="max-width: 18rem;">
  <div class="card-header bg-transparent border-success">Header</div>
  <div class="card-body text-success">
    <h5 class="card-title">Success card title</h5>
    <p class="card-text">Some quick example text to build on the card title and make up the bulk of the card's content.</p>
  </div>
  <div class="card-footer bg-transparent border-success">Footer</div>
</div>

卡片布局

除了为卡片中的内容设置样式外,Bootstrap 还包括一些用于布置卡片系列的选项。目前,这些布局选项还没有响应

卡组

使用卡片组将卡片呈现为具有相同宽度和高度列的单个附加元素。卡片组从堆叠开始,并用于从断点display: flex;开始以统一尺寸连接。sm

PlaceholderImage cap
卡片名称

这是一张更宽的卡片,下面有支持文本作为附加内容的自然引导。这个内容有点长。

最后更新于 3 分钟前

PlaceholderImage cap
卡片名称

这张卡片在下面有支持文本作为附加内容的自然引导。

最后更新于 3 分钟前

PlaceholderImage cap
卡片名称

这是一张更宽的卡片,下面有支持文本作为附加内容的自然引导。这张卡片比第一张卡片的内容更长,显示了等高动作。

最后更新于 3 分钟前

网页格式
<div class="card-group">
  <div class="card">
    <img src="..." class="card-img-top" alt="...">
    <div class="card-body">
      <h5 class="card-title">Card title</h5>
      <p class="card-text">This is a wider card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
      <p class="card-text"><small class="text-muted">Last updated 3 mins ago</small></p>
    </div>
  </div>
  <div class="card">
    <img src="..." class="card-img-top" alt="...">
    <div class="card-body">
      <h5 class="card-title">Card title</h5>
      <p class="card-text">This card has supporting text below as a natural lead-in to additional content.</p>
      <p class="card-text"><small class="text-muted">Last updated 3 mins ago</small></p>
    </div>
  </div>
  <div class="card">
    <img src="..." class="card-img-top" alt="...">
    <div class="card-body">
      <h5 class="card-title">Card title</h5>
      <p class="card-text">This is a wider card with supporting text below as a natural lead-in to additional content. This card has even longer content than the first to show that equal height action.</p>
      <p class="card-text"><small class="text-muted">Last updated 3 mins ago</small></p>
    </div>
  </div>
</div>

使用带页脚的卡片组时,它们的内容会自动对齐。

PlaceholderImage cap
卡片名称

这是一张更宽的卡片,下面有支持文本作为附加内容的自然引导。这个内容有点长。

PlaceholderImage cap
卡片名称

这张卡片在下面有支持文本作为附加内容的自然引导。

PlaceholderImage cap
卡片名称

这是一张更宽的卡片,下面有支持文本作为附加内容的自然引导。这张卡片比第一张卡片的内容更长,显示了等高动作。

网页格式
<div class="card-group">
  <div class="card">
    <img src="..." class="card-img-top" alt="...">
    <div class="card-body">
      <h5 class="card-title">Card title</h5>
      <p class="card-text">This is a wider card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
    </div>
    <div class="card-footer">
      <small class="text-muted">Last updated 3 mins ago</small>
    </div>
  </div>
  <div class="card">
    <img src="..." class="card-img-top" alt="...">
    <div class="card-body">
      <h5 class="card-title">Card title</h5>
      <p class="card-text">This card has supporting text below as a natural lead-in to additional content.</p>
    </div>
    <div class="card-footer">
      <small class="text-muted">Last updated 3 mins ago</small>
    </div>
  </div>
  <div class="card">
    <img src="..." class="card-img-top" alt="...">
    <div class="card-body">
      <h5 class="card-title">Card title</h5>
      <p class="card-text">This is a wider card with supporting text below as a natural lead-in to additional content. This card has even longer content than the first to show that equal height action.</p>
    </div>
    <div class="card-footer">
      <small class="text-muted">Last updated 3 mins ago</small>
    </div>
  </div>
</div>

网格卡

使用 Bootstrap 网格系统及其.row-cols来控制每行显示的网格列数(包裹在卡片周围)。例如,此处.row-cols-1将卡片布置在一列上,并.row-cols-md-2从中间断点向上将四张卡片分成多行等宽。

PlaceholderImage cap
卡片名称

这是一张较长的卡片,下面有支持文本作为附加内容的自然引导。这个内容有点长。

PlaceholderImage cap
卡片名称

这是一张较长的卡片,下面有支持文本作为附加内容的自然引导。这个内容有点长。

PlaceholderImage cap
卡片名称

这是一张较长的卡片,下面有支持文本作为附加内容的自然引导。

PlaceholderImage cap
卡片名称

这是一张较长的卡片,下面有支持文本作为附加内容的自然引导。这个内容有点长。

网页格式
<div class="row row-cols-1 row-cols-md-2 g-4">
  <div class="col">
    <div class="card">
      <img src="..." class="card-img-top" alt="...">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This is a longer card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
      </div>
    </div>
  </div>
  <div class="col">
    <div class="card">
      <img src="..." class="card-img-top" alt="...">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This is a longer card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
      </div>
    </div>
  </div>
  <div class="col">
    <div class="card">
      <img src="..." class="card-img-top" alt="...">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This is a longer card with supporting text below as a natural lead-in to additional content.</p>
      </div>
    </div>
  </div>
  <div class="col">
    <div class="card">
      <img src="..." class="card-img-top" alt="...">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This is a longer card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
      </div>
    </div>
  </div>
</div>

将其更改为.row-cols-3,您将看到第四张卡片包装。

PlaceholderImage cap
卡片名称

这是一张较长的卡片,下面有支持文本作为附加内容的自然引导。这个内容有点长。

PlaceholderImage cap
卡片名称

这是一张较长的卡片,下面有支持文本作为附加内容的自然引导。这个内容有点长。

PlaceholderImage cap
卡片名称

这是一张较长的卡片,下面有支持文本作为附加内容的自然引导。

PlaceholderImage cap
卡片名称

这是一张较长的卡片,下面有支持文本作为附加内容的自然引导。这个内容有点长。

网页格式
<div class="row row-cols-1 row-cols-md-3 g-4">
  <div class="col">
    <div class="card">
      <img src="..." class="card-img-top" alt="...">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This is a longer card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
      </div>
    </div>
  </div>
  <div class="col">
    <div class="card">
      <img src="..." class="card-img-top" alt="...">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This is a longer card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
      </div>
    </div>
  </div>
  <div class="col">
    <div class="card">
      <img src="..." class="card-img-top" alt="...">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This is a longer card with supporting text below as a natural lead-in to additional content.</p>
      </div>
    </div>
  </div>
  <div class="col">
    <div class="card">
      <img src="..." class="card-img-top" alt="...">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This is a longer card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
      </div>
    </div>
  </div>
</div>

当您需要相同的高度时,添加.h-100到卡片中。如果你想要默认等高,你可以$card-height: 100%在 Sass 中设置。

PlaceholderImage cap
卡片名称

这是一张较长的卡片,下面有支持文本作为附加内容的自然引导。这个内容有点长。

PlaceholderImage cap
卡片名称

这是一张短卡。

PlaceholderImage cap
卡片名称

这是一张较长的卡片,下面有支持文本作为附加内容的自然引导。

PlaceholderImage cap
卡片名称

这是一张较长的卡片,下面有支持文本作为附加内容的自然引导。这个内容有点长。

网页格式
<div class="row row-cols-1 row-cols-md-3 g-4">
  <div class="col">
    <div class="card h-100">
      <img src="..." class="card-img-top" alt="...">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This is a longer card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
      </div>
    </div>
  </div>
  <div class="col">
    <div class="card h-100">
      <img src="..." class="card-img-top" alt="...">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This is a short card.</p>
      </div>
    </div>
  </div>
  <div class="col">
    <div class="card h-100">
      <img src="..." class="card-img-top" alt="...">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This is a longer card with supporting text below as a natural lead-in to additional content.</p>
      </div>
    </div>
  </div>
  <div class="col">
    <div class="card h-100">
      <img src="..." class="card-img-top" alt="...">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This is a longer card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
      </div>
    </div>
  </div>
</div>

就像卡片组一样,卡片页脚会自动对齐。

PlaceholderImage cap
卡片名称

这是一张更宽的卡片,下面有支持文本作为附加内容的自然引导。这个内容有点长。

PlaceholderImage cap
卡片名称

这张卡片在下面有支持文本作为附加内容的自然引导。

PlaceholderImage cap
卡片名称

这是一张更宽的卡片,下面有支持文本作为附加内容的自然引导。这张卡片比第一张卡片的内容更长,显示了等高动作。

网页格式
<div class="row row-cols-1 row-cols-md-3 g-4">
  <div class="col">
    <div class="card h-100">
      <img src="..." class="card-img-top" alt="...">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This is a wider card with supporting text below as a natural lead-in to additional content. This content is a little bit longer.</p>
      </div>
      <div class="card-footer">
        <small class="text-muted">Last updated 3 mins ago</small>
      </div>
    </div>
  </div>
  <div class="col">
    <div class="card h-100">
      <img src="..." class="card-img-top" alt="...">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This card has supporting text below as a natural lead-in to additional content.</p>
      </div>
      <div class="card-footer">
        <small class="text-muted">Last updated 3 mins ago</small>
      </div>
    </div>
  </div>
  <div class="col">
    <div class="card h-100">
      <img src="..." class="card-img-top" alt="...">
      <div class="card-body">
        <h5 class="card-title">Card title</h5>
        <p class="card-text">This is a wider card with supporting text below as a natural lead-in to additional content. This card has even longer content than the first to show that equal height action.</p>
      </div>
      <div class="card-footer">
        <small class="text-muted">Last updated 3 mins ago</small>
      </div>
    </div>
  </div>
</div>

石工

v4我们使用纯 CSS 技术来模仿类似Masonry的柱子的行为,但是这种技术带来了很多令人不快的副作用。如果你想在 中有这种类型的布局v5,你可以使用 Masonry 插件。Bootstrap 中不包含 Masonry,但我们制作了一个演示示例来帮助您入门。

CSS

变量

添加于 v5.2.0

作为 Bootstrap 不断发展的 CSS 变量方法的一部分,卡片现在使用本地 CSS 变量.card来增强实时定制。CSS 变量的值是通过 Sass 设置的,因此仍然支持 Sass 自定义。

  --#{$prefix}card-spacer-y: #{$card-spacer-y};
  --#{$prefix}card-spacer-x: #{$card-spacer-x};
  --#{$prefix}card-title-spacer-y: #{$card-title-spacer-y};
  --#{$prefix}card-title-color: #{$card-title-color};
  --#{$prefix}card-subtitle-color: #{$card-subtitle-color};
  --#{$prefix}card-border-width: #{$card-border-width};
  --#{$prefix}card-border-color: #{$card-border-color};
  --#{$prefix}card-border-radius: #{$card-border-radius};
  --#{$prefix}card-box-shadow: #{$card-box-shadow};
  --#{$prefix}card-inner-border-radius: #{$card-inner-border-radius};
  --#{$prefix}card-cap-padding-y: #{$card-cap-padding-y};
  --#{$prefix}card-cap-padding-x: #{$card-cap-padding-x};
  --#{$prefix}card-cap-bg: #{$card-cap-bg};
  --#{$prefix}card-cap-color: #{$card-cap-color};
  --#{$prefix}card-height: #{$card-height};
  --#{$prefix}card-color: #{$card-color};
  --#{$prefix}card-bg: #{$card-bg};
  --#{$prefix}card-img-overlay-padding: #{$card-img-overlay-padding};
  --#{$prefix}card-group-margin: #{$card-group-margin};
  

Sass 变量

$card-spacer-y:                     $spacer;
$card-spacer-x:                     $spacer;
$card-title-spacer-y:               $spacer * .5;
$card-title-color:                  null;
$card-subtitle-color:               null;
$card-border-width:                 var(--#{$prefix}border-width);
$card-border-color:                 var(--#{$prefix}border-color-translucent);
$card-border-radius:                var(--#{$prefix}border-radius);
$card-box-shadow:                   null;
$card-inner-border-radius:          subtract($card-border-radius, $card-border-width);
$card-cap-padding-y:                $card-spacer-y * .5;
$card-cap-padding-x:                $card-spacer-x;
$card-cap-bg:                       rgba(var(--#{$prefix}body-color-rgb), .03);
$card-cap-color:                    null;
$card-height:                       null;
$card-color:                        null;
$card-bg:                           var(--#{$prefix}body-bg);
$card-img-overlay-padding:          $spacer;
$card-group-margin:                 $grid-gutter-width * .5;