cards.mdx 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343
  1. ---
  2. title: Cards
  3. description: Cards are flexible user interface elements, which help organize content into meaningful sections and make it easier to display on different screen sizes. Cards contain various smaller components, such as images, text, links and buttons and may act as an entry to more detailed information, helping users scan the page quickly and find the most relevant content.
  4. bootstrapLink: components/card/
  5. ---
  6. ## Default card
  7. Use the `.card` and `.card-body` classes to create a card and use it as the basis for a more advanced card design. A card is a perfect way to organize content and make it look neat and tidy.
  8. ```html example code centered columns={1}
  9. <div class="card">
  10. <div class="card-body">
  11. <p>This is some text within a card body.</p>
  12. </div>
  13. </div>
  14. ```
  15. ## Card padding
  16. You can change the padding of a newly created card. To do it, use the `.card-sm`, `.card-md` or `.card-lg` classes.
  17. Cards with the `.card-sm` class are well suited for small items such as widgets, etc., while the `.card-lg` class can be used for large blocks of text. Padding will be automatically reduced on small devices, to fit the screen size.
  18. ```html example vertical centered separated height={500}
  19. <div class="card card-sm">
  20. <div class="card-body">
  21. This is some text within a card body.
  22. </div>
  23. </div>
  24. <div class="card">
  25. <div class="card-body">
  26. This is some text within a card body.
  27. </div>
  28. </div>
  29. <div class="card card-md">
  30. <div class="card-body">
  31. This is some text within a card body.
  32. </div>
  33. </div>
  34. <div class="card card-lg">
  35. <div class="card-body">
  36. This is some text within a card body.
  37. </div>
  38. </div>
  39. ```
  40. ```html
  41. <div class="card card-sm">...</div>
  42. <div class="card">...</div>
  43. <div class="card card-md">...</div>
  44. <div class="card card-lg">...</div>
  45. ```
  46. ## Card with title
  47. Add a title to your card by including the `.card-title` class within `.card-body`. You can also place the title inside the `.card-header` element to separate the title from the content with a horizontal line.
  48. ```html code example vertical centered separated height={400}
  49. <div class="card">
  50. <div class="card-body">
  51. <h3 class="card-title">Card title</h3>
  52. <p class="text-secondary">This is some text within a card body.</p>
  53. </div>
  54. </div>
  55. <div class="card">
  56. <div class="card-header">
  57. <h3 class="card-title">Card title</h3>
  58. </div>
  59. <div class="card-body">
  60. <p class="text-secondary">This is some text within a card body.</p>
  61. </div>
  62. </div>
  63. ```
  64. ## Card with title and image
  65. To create a more visually appealing card, add a title and an image. Thanks to that, the card will go well with your interface design and draw users' attention.
  66. ```html example centered columns={1} height={500} code
  67. <div class="card">
  68. <!-- Photo -->
  69. <div class="img-responsive img-responsive-21x9 card-img-top" style="background-image: url(/samples/photos/cup-of-coffee-and-an-open-book.jpg)"></div>
  70. <div class="card-body">
  71. <h3 class="card-title">Card with title and image</h3>
  72. <p class="text-secondary">Lorem ipsum dolor sit amet, consectetur adipisicing elit. Aperiam deleniti fugit incidunt, iste, itaque minima
  73. neque pariatur perferendis sed suscipit velit vitae voluptatem.</p>
  74. </div>
  75. </div>
  76. ```
  77. ## Blog post card
  78. Add an image to your blog post card to make it eye-catching. You can do it by adding the image in the `.card-img-top` class. Thanks to the `.d-flex` and `.flex-column` classes within `.card-body`, the author details will be displayed at the bottom of the card.
  79. ```html example centered columns={1} height={600} code
  80. <div class="card d-flex flex-column">
  81. <a href="#">
  82. <img class="card-img-top" src="/samples/photos/book-on-the-grass.jpg" alt="" />
  83. </a>
  84. <div class="card-body d-flex flex-column">
  85. <h3 class="card-title"><a href="#">How do you know she is a witch?</a></h3>
  86. <div class="text-secondary">Are you suggesting that coconuts migrate? No, no, no! Yes, yes. A bit. But she's got a wart. You ...</div>
  87. <div class="d-flex align-items-center pt-4 mt-auto">
  88. <span class="avatar" style="background-image: url(/samples/avatars/023m.jpg)"></span>
  89. <div class="ms-3">
  90. <a href="#" class="text-body">Maryjo Lebarree</a>
  91. <div class="text-secondary">3 days ago</div>
  92. </div>
  93. <div class="ms-auto">
  94. <a href="#" class="icon d-none d-md-inline-block ms-3 text-secondary">
  95. <svg xmlns="http://www.w3.org/2000/svg" class="icon icon-tabler icon-tabler-heart" width="24" height="24" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round">
  96. <path d="M19.5 12.572l-7.5 7.428l-7.5 -7.428a5 5 0 1 1 7.5 -6.566a5 5 0 1 1 7.5 6.572"></path>
  97. </svg>
  98. </a>
  99. </div>
  100. </div>
  101. </div>
  102. </div>
  103. ```
  104. ## Row deck
  105. Add the `.row-deck` class to `.row`, if you want to display several cards next to one another. Thanks to that, they will all have the same height.
  106. ```html code example centered height="220px"
  107. <div class="row row-deck">
  108. <div class="col-md-4">
  109. <div class="card">
  110. <div class="card-body">Short content</div>
  111. </div>
  112. </div>
  113. <div class="col-md-4">
  114. <div class="card">
  115. <div class="card-body">Extra long content of card. Lorem ipsum dolor sit amet, consetetur sadipscing elitr</div>
  116. </div>
  117. </div>
  118. <div class="col-md-4">
  119. <div class="card">
  120. <div class="card-body">Short content</div>
  121. </div>
  122. </div>
  123. </div>
  124. ```
  125. ## Post card with aside image
  126. You can also add an image on the left side of the card. To do it, add the `.card-aside` class to the element with the `.card` class. Then add the image in the `.card-aside-column` element and it will be automatically centered and scaled to the right size.
  127. ```html example columns={2} centered height={400} code
  128. <div class="card d-flex flex-column">
  129. <div class="row row-0 flex-fill">
  130. <div class="col-md-3">
  131. <a href="#">
  132. <img src="/samples/photos/a-woman-works-on-a-laptop-at-home.jpg" class="w-100 h-100 object-cover" alt="Card side image" />
  133. </a>
  134. </div>
  135. <div class="col">
  136. <div class="card-body">
  137. <h3 class="card-title"><a href="#">Shut up!</a></h3>
  138. <div class="text-secondary">Burn her! How do you know she is a witch? You don't frighten us, English pig-dogs! Go and boil yo...</div>
  139. <div class="d-flex align-items-center pt-4 mt-auto">
  140. <span class="avatar" style="background-image: url(/samples/avatars/029m.jpg)"></span>
  141. <div class="ms-3">
  142. <a href="#" class="text-body">Egan Poetz</a>
  143. <div class="text-secondary">3 days ago</div>
  144. </div>
  145. <div class="ms-auto">
  146. <a href="#" class="icon d-none d-md-inline-block ms-3 text-red">
  147. <svg xmlns="http://www.w3.org/2000/svg" class="icon icon-tabler icon-tabler-heart" width="24" height="24" viewBox="0 0 24 24" stroke-width="2" stroke="currentColor" fill="none" stroke-linecap="round" stroke-linejoin="round">
  148. <path d="M19.5 12.572l-7.5 7.428l-7.5 -7.428a5 5 0 1 1 7.5 -6.566a5 5 0 1 1 7.5 6.572"></path>
  149. </svg>
  150. </a>
  151. </div>
  152. </div>
  153. </div>
  154. </div>
  155. </div>
  156. </div>
  157. ```
  158. ## Color variations
  159. Add a status color to your card, either at the top or on the side of the card, to customise it and make it more eye-catching.
  160. ```html example columns={2} centered height={400}
  161. <div class="row row-deck">
  162. <div class="col-md-6">
  163. <div class="card">
  164. <div class="card-status-top bg-danger"></div>
  165. <div class="card-body">
  166. <h3 class="card-title">Card with top status</h3>
  167. <p class="text-secondary">Lorem ipsum dolor sit amet, consectetur adipisicing elit. Aperiam deleniti fugit incidunt, iste, itaque minima
  168. neque pariatur perferendis sed suscipit velit vitae voluptatem.</p>
  169. </div>
  170. </div>
  171. </div>
  172. <div class="col-md-6">
  173. <div class="card">
  174. <div class="card-status-start bg-green"></div>
  175. <div class="card-body">
  176. <h3 class="card-title">Card with side status</h3>
  177. <p class="text-secondary">Lorem ipsum dolor sit amet, consectetur adipisicing elit. Aperiam deleniti fugit incidunt, iste, itaque minima
  178. neque pariatur perferendis sed suscipit velit vitae voluptatem.</p>
  179. </div>
  180. </div>
  181. </div>
  182. </div>
  183. ```
  184. ```html
  185. <div class="card">
  186. <div class="card-status-top bg-danger"></div>
  187. <div class="card-body">
  188. <h3 class="card-title">Card with top status</h3>
  189. <p class="text-secondary">Lorem ipsum dolor sit amet, consectetur adipisicing elit. Aperiam deleniti fugit incidunt, iste, itaque minima
  190. neque pariatur perferendis sed suscipit velit vitae voluptatem.</p>
  191. </div>
  192. </div>
  193. <div class="card">
  194. <div class="card-status-start bg-green"></div>
  195. <div class="card-body">
  196. <h3 class="card-title">Card with side status</h3>
  197. <p class="text-secondary">Lorem ipsum dolor sit amet, consectetur adipisicing elit. Aperiam deleniti fugit incidunt, iste, itaque minima
  198. neque pariatur perferendis sed suscipit velit vitae voluptatem.</p>
  199. </div>
  200. </div>
  201. ```
  202. ## Stacked card
  203. Use the `card-stacked` class to stack up multiple cards, if you want to save screen space or create a visually appealing effect.
  204. ```html code example columns={1} centered height={300}
  205. <div class="card card-stacked">
  206. <div class="card-body">
  207. <h3 class="card-title">Stacked card</h3>
  208. <p class="text-secondary">Lorem ipsum dolor sit amet, consectetur adipisicing elit. Aperiam deleniti fugit incidunt, iste, itaque minima
  209. neque pariatur perferendis sed suscipit velit vitae voluptatem.</p>
  210. </div>
  211. </div>
  212. ```
  213. ## Tabbed card
  214. Organize multiple cards into tabs to be able to display more content in a well-organized way and allow users to alternate between them easily.
  215. ```html example columns={2} centered height={400}
  216. <div class="card-tabs">
  217. <ul class="nav nav-tabs">
  218. <li class="nav-item"><a href="#tab-top-1" class="nav-link active" data-bs-toggle="tab">Tab 1</a></li>
  219. <li class="nav-item"><a href="#tab-top-2" class="nav-link" data-bs-toggle="tab">Tab 2</a></li>
  220. <li class="nav-item"><a href="#tab-top-3" class="nav-link" data-bs-toggle="tab">Tab 3</a></li>
  221. <li class="nav-item"><a href="#tab-top-4" class="nav-link" data-bs-toggle="tab">Tab 4</a></li>
  222. </ul>
  223. <div class="tab-content">
  224. <div id="tab-top-1" class="card tab-pane active show">
  225. <div class="card-body">
  226. <div class="card-title">Content of tab #1</div>
  227. <p class="text-secondary">
  228. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Adipisci, alias aliquid distinctio dolorem expedita, fugiat hic magni molestiae molestias odit.
  229. </p>
  230. </div>
  231. </div>
  232. <div id="tab-top-2" class="card tab-pane">
  233. <div class="card-body">
  234. <div class="card-title">Content of tab #2</div>
  235. <p class="text-secondary">
  236. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Adipisci, alias aliquid distinctio dolorem expedita, fugiat hic magni molestiae molestias odit.
  237. </p>
  238. </div>
  239. </div>
  240. <div id="tab-top-3" class="card tab-pane">
  241. <div class="card-body">
  242. <div class="card-title">Content of tab #3</div>
  243. <p class="text-secondary">
  244. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Adipisci, alias aliquid distinctio dolorem expedita, fugiat hic magni molestiae molestias odit.
  245. </p>
  246. </div>
  247. </div>
  248. <div id="tab-top-4" class="card tab-pane">
  249. <div class="card-body">
  250. <div class="card-title">Content of tab #4</div>
  251. <p class="text-secondary">
  252. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Adipisci, alias aliquid distinctio dolorem expedita, fugiat hic magni molestiae molestias odit.
  253. </p>
  254. </div>
  255. </div>
  256. </div>
  257. </div>
  258. ```
  259. ```html
  260. <!-- Cards with tabs component -->
  261. <div class="card-tabs">
  262. <!-- Cards navigation -->
  263. <ul class="nav nav-tabs">
  264. <li class="nav-item"><a href="#tab-top-1" class="nav-link active" data-bs-toggle="tab">Tab 1</a></li>
  265. <li class="nav-item"><a href="#tab-top-2" class="nav-link" data-bs-toggle="tab">Tab 2</a></li>
  266. <li class="nav-item"><a href="#tab-top-3" class="nav-link" data-bs-toggle="tab">Tab 3</a></li>
  267. <li class="nav-item"><a href="#tab-top-4" class="nav-link" data-bs-toggle="tab">Tab 4</a></li>
  268. </ul>
  269. <div class="tab-content">
  270. <!-- Content of card #1 -->
  271. <div id="tab-top-1" class="card tab-pane active show">
  272. <div class="card-body">
  273. <div class="card-title">Content of tab #1</div>
  274. <p class="text-secondary">
  275. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Adipisci, alias aliquid distinctio dolorem expedita, fugiat hic magni molestiae molestias odit.
  276. </p>
  277. </div>
  278. </div>
  279. <!-- Content of card #2 -->
  280. <div id="tab-top-2" class="card tab-pane">
  281. <div class="card-body">
  282. <div class="card-title">Content of tab #2</div>
  283. <p class="text-secondary">
  284. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Adipisci, alias aliquid distinctio dolorem expedita, fugiat hic magni molestiae molestias odit.
  285. </p>
  286. </div>
  287. </div>
  288. <!-- Content of card #3 -->
  289. <div id="tab-top-3" class="card tab-pane">
  290. <div class="card-body">
  291. <div class="card-title">Content of tab #3</div>
  292. <p class="text-secondary">
  293. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Adipisci, alias aliquid distinctio dolorem expedita, fugiat hic magni molestiae molestias odit.
  294. </p>
  295. </div>
  296. </div>
  297. <!-- Content of card #4 -->
  298. <div id="tab-top-4" class="card tab-pane">
  299. <div class="card-body">
  300. <div class="card-title">Content of tab #4</div>
  301. <p class="text-secondary">
  302. Lorem ipsum dolor sit amet, consectetur adipisicing elit. Adipisci, alias aliquid distinctio dolorem expedita, fugiat hic magni molestiae molestias odit.
  303. </p>
  304. </div>
  305. </div>
  306. </div>
  307. </div>
  308. ```