Progress bar

Progress components are built with two HTML elements, some CSS to set the width, and a few attributes.

  • We use the .progress as a wrapper to indicate the max value of the progress bar.
  • We use the inner .progress-bar to indicate the progress so far.
  • The .progress-bar requires an inline style, utility class, or custom CSS to set their width.
  • The .progress-bar also requires some role and aria attributes to make it accessible.

Put that all together, and you have the following examples.

Another Style

Add labels to your progress bars by placing text within the .progress-bar.

HTML/CSS
75%
Design
85%
Photoshop
65%
Bootstrap
95%

Labels

Add labels to your progress bars by placing text within the .progress-bar.

25%

Height

We only set a height value on the .progress-bar, so if you change that value the outer .progress will automatically resize accordingly.

Backgrounds

Use background utility classes to change the appearance of individual progress bars.

Multiple bars

Include multiple progress bars in a progress component if you need.

Striped

Add .progress-bar-striped to any .progress-bar to apply a stripe via CSS gradient over the progress bar’s background color.

Animated stripes

The striped gradient can also be animated. Add .progress-bar-animated to .progress-bar to animate the stripes right to left via CSS3 animations.

Animated progress bars don’t work in Opera 12—as they don’t support CSS3 animations.