Skip to content

Card

A card is a generic container for grouping related UI elements and content.

Introduction

The Joy UI Card component includes several complementary utility components to handle various use cases:

  • Card: a surface-level container for grouping related components.
  • Card Overflow: a supplemental wrapper that expands a Card's contents to fill all edges.
  • Card Cover: an optional container for displaying background images and gradient layers behind the Card Content.
  • Card Content: an optional wrapper that brings content to the front (commonly but not always used with the Card Cover).
  • Card Actions: an optional wrapper that groups a set of buttons.

Basics

<span class="token keyword">import</span> Card <span class="token keyword">from</span> <span class="token string">'@mui/joy/Card'</span><span class="token punctuation">;</span>

Card is a surface-level container for grouping related components. The demo below shows a typical Card that groups together Typography, Aspect Ratio, and Button components, among others:

Yosemite National Park

April 24 to May 02, 2021

Total price:

$2,900

Customization

Expand to fill

<span class="token keyword">import</span> CardOverflow <span class="token keyword">from</span> <span class="token string">'@mui/joy/CardOverflow'</span><span class="token punctuation">;</span>

By default, the Card component adds padding around the outer edges of its contents. To eliminate this white space, add the Card Overflow component inside the Card as a wrapper around the content to be expanded.

Yosemite National Park

California


6.3k views


1 hour ago

Card layers

<span class="token keyword">import</span> CardCover <span class="token keyword">from</span> <span class="token string">'@mui/joy/CardCover'</span><span class="token punctuation">;</span>
<span class="token keyword">import</span> CardContent <span class="token keyword">from</span> <span class="token string">'@mui/joy/CardContent'</span><span class="token punctuation">;</span>

The default Card provides a single flat surface for other components to sit on top of. Use the Card Cover and Card Content components to expose multiple layers between a Card and the UI elements on its surface.

Card Cover makes it possible to add images, videos, and color and gradient overlays underneath the Card Content. Hover your mouse on the demo below to see how the layers are stacked:

Card

Card Cover

Card Content

Images and videos

Use an image or a video element inside the Card Cover to display media. The component uses object-fit: cover to fill the whole Card by default.

  • Image
  • Video

Gradient overlay

To create a gradient overlay—frequently seen when a bright image is used as a background—insert an additional Card Cover component between the image layer and the content layer. You can add any number of Card Covers to create more sophisticated stacked layers this way.

Yosemite National Park

California, USA

Horizontal alignment

Card contents are arranged in a column by default. For horizontal alignment, add the orientation="horizontal" prop to the Card. If present, the Card Overflow component will adapt accordingly.

Yosemite Park

California, USA

Ticket

Actions

Cards often include actions that users can take, like proceeding to a new page or section of the app. There may be individual (discrete) actions within a given card, or the entire card itself may trigger an action when clicked or tapped.

The following sections explain how to approach each of these scenarios.

Bottom actions

Cards often include buttons at the bottom section. Use CardActions component as a wrapper of those buttons to create proper spacing around them.

The demo below also use buttonFlex prop to set the ideal width of the buttons to 120px while allowing them to shrink if necessary. To learn more about CSS flex, visit MDN's guide.

+4K
NYC Coders

We are a community of developers prepping for coding interviews, participate, chat with others and get better at interviewing.

Discrete actions

By default, action elements like links and buttons sit above the surface-level interactive area of the Card. In some cases, you might have to adjust the z-index to bring these elements to the front—for instance, the Favorite Icon Button in the demo below needs a higher z-index in order to sit on top of its Aspect Ratio sibling:

Whole Card actions

To make the entire Card clickable, add a Link component to the title (or some other important text content) inside the Card. Then add the overlay prop to the Link to spread it across the Card as a whole.

Yosemite Park

California, USA

Cool weather all day long

CSS variable playground

Play around with the CSS variables available to the Card component to see how the design changes. You can use these to customize the component with both the sx prop and the theme.

Card title

A very very long description.

70%

Card title

Long description.

CSS variables

px

Default as 16px

px

Default as 12px
<Card>

Common examples

Bio card

PRO

Josephine Blanton

Hello, this is my bio and I am a PRO member of MUI. I am a developer and I love to code.

Credit card form

Add new card


Congratulations card

🎊 Congrats Julia 🎊

You just gain one Cookhat for Salad cooking. Share your achievement with your friends.

FAQ card

89

FAQs answered, see if yours is one of them.

Need Some Help?

Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor.

License card

Individual License

$58 /month

This license allows you to use the Symbol System Design with unlimited amount of personal and commercial projects.

Compatible with Sketch 55+

Pricing card

BASIC

Professional


  • Virtual Credit Cards
  • Financial Analytics
  • Checking Account
  • API Integration

3.990€ / month
MOST POPULAR

Unlimited


  • Virtual Credit Cards
  • Financial Analytics
  • Checking Account
  • API Integration
  • Cancel Anytime

5.990€ / month

Product card

This example demonstrates the automatic adjustment when a button is placed as a only child of a CardOverflow component. The button will be stretched to fill the entire area of the CardOverflow and the bottom corner radius is also adjusted.

Bluetooth Headset

Super Rockez A400

2,900 THBLowest price

(Only 7 left in stock!)

User card

Combining CSS min-width with clamp, a horizontal card can be stacked when it reaches a certain width or below.

The example below shows a user card that stacks when the card's width is equal or below 500px. The drag handle is at the bottom right corner of the card.

Alex Morrison

Senior Journalist

Articles

34

Followers

980

Rating

8.9

Instagram post

MUI

The React component library you always wanted

Dribbble shot

National Park

Featured
11710.4k

Resizable container

This demo uses a technique similar to Heydon Pickering's Flexbox Holy Albatross to create a stretchable Card that switches between vertical and horizontal alignment when its width passes a specified threshold—without using media queries to define breakpoints. Try resizing it by clicking and dragging the bottom-right corner to see how it behaves.

Yosemite National Park

California, USA

Y

Designed by

Nature itself

Anatomy

The Card component and all of its supplementary components are composed of a single root <div>:

<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">"</span>MuiCard-root<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
  <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">"</span>MuiCardCover-root<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
    <span class="token comment">&lt;!-- optional Card Cover layer --></span>
  <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">></span></span>
  <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">"</span>MuiCardContent-root<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
    <span class="token comment">&lt;!-- optional Card Content layer --></span>
  <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">></span></span>
  <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">"</span>MuiCardOverflow-root<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
    <span class="token comment">&lt;!-- optional Card Overflow utility --></span>
  <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">></span></span>
  <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>div</span> <span class="token attr-name">class</span><span class="token attr-value"><span class="token punctuation attr-equals">=</span><span class="token punctuation">"</span>MuiCardActions-root<span class="token punctuation">"</span></span><span class="token punctuation">></span></span>
    <span class="token comment">&lt;!-- optional Card Actions layer --></span>
  <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">></span></span>
<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>div</span><span class="token punctuation">></span></span>

API

See the documentation below for a complete reference to all of the props and classes available to the components mentioned here.