The card component comprises several elements that you can mix and match:
card
: the main container
card-header
: a horizontal bar with a shadow
card-header-title
: a left-aligned bold text
card-header-icon
: a placeholder for an icon
card-image
: a fullwidth container for a responsive image
card-content
: a multi-purpose container for any other element
card-footer
: a horizontal list of controls
card-footer-item
: a repeatable list item
You can center the card-header-title
by appending the is-centered
modifier.
Example
Lorem ipsum dolor sit amet, consectetur adipiscing elit.
Phasellus nec iaculis mauris.
@bulmaio .
#css #responsive
11:09 PM - 1 Jan 2016
HTML
<div class= "card" >
<div class= "card-image" >
<figure class= "image is-4by3" >
<img src= "https://bulma.io/images/placeholders/1280x960.png" alt= "Placeholder image" >
</figure>
</div>
<div class= "card-content" >
<div class= "media" >
<div class= "media-left" >
<figure class= "image is-48x48" >
<img src= "https://bulma.io/images/placeholders/96x96.png" alt= "Placeholder image" >
</figure>
</div>
<div class= "media-content" >
<p class= "title is-4" > John Smith</p>
<p class= "subtitle is-6" > @johnsmith</p>
</div>
</div>
<div class= "content" >
Lorem ipsum dolor sit amet, consectetur adipiscing elit.
Phasellus nec iaculis mauris. <a> @bulmaio</a> .
<a href= "#" > #css</a> <a href= "#" > #responsive</a>
<br>
<time datetime= "2016-1-1" > 11:09 PM - 1 Jan 2016</time>
</div>
</div>
</div>
Card parts
#
The card-header
can have a title and a Bulma icon
:
HTML
<div class= "card" >
<header class= "card-header" >
<p class= "card-header-title" >
Card header
</p>
<button class= "card-header-icon" aria-label= "more options" >
<span class= "icon" >
<i class= "fas fa-angle-down" aria-hidden= "true" ></i>
</span>
</button>
</header>
</div>
The card-image
is a container for a Bulma image
element:
HTML
<div class= "card" >
<div class= "card-image" >
<figure class= "image is-4by3" >
<img src= "https://bulma.io/images/placeholders/1280x960.png" alt= "Placeholder image" >
</figure>
</div>
</div>
The card-content
is the main part, ideal for text content , thanks to its padding:
Example
Lorem ipsum leo risus, porta ac consectetur ac, vestibulum at eros. Donec id elit non mi porta gravida at eget metus. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Cras mattis consectetur purus sit amet fermentum.
HTML
<div class= "card" >
<div class= "card-content" >
<div class= "content" >
Lorem ipsum leo risus, porta ac consectetur ac, vestibulum at eros. Donec id elit non mi porta gravida at eget metus. Cum sociis natoque penatibus et magnis dis parturient montes, nascetur ridiculus mus. Cras mattis consectetur purus sit amet fermentum.
</div>
</div>
</div>
The card-footer
acts as a list of for several card-footer-item
elements:
HTML
<div class= "card" >
<footer class= "card-footer" >
<a href= "#" class= "card-footer-item" > Save</a>
<a href= "#" class= "card-footer-item" > Edit</a>
<a href= "#" class= "card-footer-item" > Delete</a>
</footer>
</div>
Examples
#
Example
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Phasellus nec iaculis mauris.
@bulmaio .
#css #responsive
11:09 PM - 1 Jan 2016
HTML
<div class= "card" >
<header class= "card-header" >
<p class= "card-header-title" >
Component
</p>
<button class= "card-header-icon" aria-label= "more options" >
<span class= "icon" >
<i class= "fas fa-angle-down" aria-hidden= "true" ></i>
</span>
</button>
</header>
<div class= "card-content" >
<div class= "content" >
Lorem ipsum dolor sit amet, consectetur adipiscing elit. Phasellus nec iaculis mauris.
<a href= "#" > @bulmaio</a> . <a href= "#" > #css</a> <a href= "#" > #responsive</a>
<br>
<time datetime= "2016-1-1" > 11:09 PM - 1 Jan 2016</time>
</div>
</div>
<footer class= "card-footer" >
<a href= "#" class= "card-footer-item" > Save</a>
<a href= "#" class= "card-footer-item" > Edit</a>
<a href= "#" class= "card-footer-item" > Delete</a>
</footer>
</div>
Example
“There are two hard things in computer science: cache invalidation, naming things, and off-by-one errors.”
Jeff Atwood
HTML
<div class= "card" >
<div class= "card-content" >
<p class= "title" >
“There are two hard things in computer science: cache invalidation, naming things, and off-by-one errors.”
</p>
<p class= "subtitle" >
Jeff Atwood
</p>
</div>
<footer class= "card-footer" >
<p class= "card-footer-item" >
<span>
View on <a href= "https://twitter.com/codinghorror/status/506010907021828096" > Twitter</a>
</span>
</p>
<p class= "card-footer-item" >
<span>
Share on <a href= "#" > Facebook</a>
</span>
</p>
</footer>
</div>
Variables
#
Name
Type
Value
Computed Value
Computed Type
variable
0 0 . 5 em 1 em -0 . 125 em rgba ( $ scheme-invert , 0 . 1 ), 0 0 px 0 1 px rgba ( $ scheme-invert , 0 . 02 )
shadow
$ card-header-background-color
string
shadow
0 0 . 125 em 0 . 25 em rgba ( $ scheme-invert , 0 . 1 )
$ card-content-background-color
string
$ card-footer-background-color
string