2017-03-03 21:57:16 +01:00
---
layout: docs
title: Display property
2017-05-28 20:25:59 +02:00
description: Quickly and responsively toggle the display value of components and more with our display utilities. Includes support for some of the more common values, as well as some extras for controlling display when printing.
2017-03-03 21:57:16 +01:00
group: utilities
2017-05-28 20:25:59 +02:00
toc: true
2017-03-03 21:57:16 +01:00
---
2017-10-19 22:14:08 +02:00
## How it works
2017-03-03 21:57:16 +01:00
2017-10-19 22:14:08 +02:00
Change the value of the [`display` property ](https://developer.mozilla.org/en-US/docs/Web/CSS/display ) with our responsive display utility classes. We purposely support only a subset of all possible values for `display` . Classes can be combined for various effects as you need.
2017-03-03 21:57:16 +01:00
2017-10-18 23:28:09 +02:00
## Notation
2019-02-04 11:22:02 +01:00
Display utility classes that apply to all [breakpoints ]({{< docsref "/layout/overview#responsive-breakpoints" >}} ), from `xs` to `xl` , have no breakpoint abbreviation in them. This is because those classes are applied from `min-width: 0;` and up, and thus are not bound by a media query. The remaining breakpoints, however, do include a breakpoint abbreviation.
2017-10-19 22:14:08 +02:00
As such, the classes are named using the format:
2017-10-23 04:34:06 +02:00
2017-10-19 22:14:08 +02:00
* `.d-{value}` for `xs`
* `.d-{breakpoint}-{value}` for `sm` , `md` , `lg` , and `xl` .
2017-10-18 23:28:09 +02:00
2018-01-11 09:26:32 +01:00
Where *value* is one of:
2017-10-18 23:28:09 +02:00
* `none`
* `inline`
* `inline-block`
* `block`
* `table`
* `table-cell`
2017-10-26 08:33:41 +02:00
* `table-row`
2017-10-18 23:28:09 +02:00
* `flex`
* `inline-flex`
2018-12-29 03:54:58 +01:00
The display values can be altered by changing the `$displays` variable and recompiling the SCSS.
2017-10-23 04:34:24 +02:00
The media queries effect screen widths with the given breakpoint *or larger* . For example, `.d-lg-none` sets `display: none;` on both `lg` and `xl` screens.
2017-10-18 23:28:09 +02:00
## Examples
2017-03-03 21:57:16 +01:00
2019-01-08 17:33:28 +01:00
{{< example > }}
2017-10-23 04:35:42 +02:00
< div class = "d-inline p-2 bg-primary text-white" > d-inline< / div >
< div class = "d-inline p-2 bg-dark text-white" > d-inline< / div >
2019-01-08 17:33:28 +01:00
{{< / example > }}
2017-03-03 21:57:16 +01:00
2019-01-08 17:33:28 +01:00
{{< example > }}
2017-10-23 04:35:42 +02:00
< span class = "d-block p-2 bg-primary text-white" > d-block< / span >
< span class = "d-block p-2 bg-dark text-white" > d-block< / span >
2019-01-08 17:33:28 +01:00
{{< / example > }}
2017-03-03 21:57:16 +01:00
2018-01-18 02:29:28 +01:00
## Hiding elements
2017-09-07 00:10:32 +02:00
2018-12-14 18:07:44 +01:00
For faster mobile-friendly development, use responsive display classes for showing and hiding elements by device. Avoid creating entirely different versions of the same site, instead hide elements responsively for each screen size.
2017-09-07 13:23:20 +02:00
2017-09-07 00:10:32 +02:00
To hide elements simply use the `.d-none` class or one of the `.d-{sm,md,lg,xl}-none` classes for any responsive screen variation.
2018-02-25 16:45:31 +01:00
To show an element only on a given interval of screen sizes you can combine one `.d-*-none` class with a `.d-*-*` class, for example `.d-none .d-md-block .d-xl-none` will hide the element for all screen sizes except on medium and large devices.
2017-09-07 13:23:20 +02:00
2019-07-15 18:59:55 +02:00
< table class = "table" >
v5: Forms update (#28450)
* Initial spike of consolidated form checks
* Stub out forms rearrangement
- Prepping to drop non-custom file and range inputs
- Prepping to merge custom and native checks and radios (with switches)
- Prepping to merge custom select with form select
- Moving docs arround so forms has it's own area given volume of CSS
* Move input group Sass file to forms subdir
* Start to split and move the docs around
* Simpler imports
* Copyediting
* delete overview file
* Remove commented out code
* remove the custom-forms import
* rewrite flex-check as form-check, replace all custom properties
* Remove old forms doc
* stub out new subpage link section
* update migration guide
* Update nav, forms overview in page nav, and descriptions
* fix check bg position
* fix margin-top calculation
* rename .custom-select to .form-select
* Update validation styles for new checks
* add some vertical margin, fix inline checks
* fix docs examples
* better way to do this contents stuff, redo the toc while i'm at it
* page restyle for docs while here
* un-callout that, edit text
* redo padding on toc
* fix toc
* start to cleanup checks docs
* Rewrite Markdown tables into HTML
* Redesign tables, redo their docs
* Replace Open Iconic icons with custom Bootstrap icons
* Redesign the docs navbar, add a subheader, redo the sidebar
* Redesign docs homepage a bit
* Simplify table style overrides for docs tables
* Simplify docs typography for page titles and reading line length
* Stub out icons page
* Part of sidebar update, remove migration from nav.yml
* Move toc CSS to separate partial
* Change appearance of overview page
* fix sidebar arrow direction
* Add footer to docs layout
* Update descriptions
* Drop the .form-group class for margin utilities
* Remove lingering form-group-margin-bottom var
* improve footer spacing
* add headings to range page
* uncomment form range css
* Rename .custom-range to .form-range
* Drop unused docs var
* Uncomment the comment
* Remove unused variable
* Fix radio image sizing
* Reboot update: reset horizontal ul and ol padding
* de-dupe IDs
* tweak toc styles
* nvm, fix dropdown versions stuff
* remove sidebar nav toggle for now
* broken html
* fix more broken html, move css
* scss linting
* comment out broken helper docs
* scope styles
* scope styles
* Fixes #25540 and fixes #26407 for v5 only
* Update sidebar once more
* Match new sidenav order
* fix syntax error
* Rename custom-file to form-file, update paths, update migration docs for previous changes in #28696
* rename back
* fix size and alignment
* rename that back too
2019-07-12 23:52:33 +02:00
< thead >
< tr >
< th > Screen size< / th >
< th > Class< / th >
< / tr >
< / thead >
< tbody >
< tr >
< td > Hidden on all< / td >
< td > < code > .d-none< / code > < / td >
< / tr >
< tr >
< td > Hidden only on xs< / td >
< td > < code > .d-none .d-sm-block< / code > < / td >
< / tr >
< tr >
< td > Hidden only on sm< / td >
< td > < code > .d-sm-none .d-md-block< / code > < / td >
< / tr >
< tr >
< td > Hidden only on md< / td >
< td > < code > .d-md-none .d-lg-block< / code > < / td >
< / tr >
< tr >
< td > Hidden only on lg< / td >
< td > < code > .d-lg-none .d-xl-block< / code > < / td >
< / tr >
< tr >
< td > Hidden only on xl< / td >
< td > < code > .d-xl-none< / code > < / td >
< / tr >
< tr >
< td > Visible on all< / td >
< td > < code > .d-block< / code > < / td >
< / tr >
< tr >
< td > Visible only on xs< / td >
< td > < code > .d-block .d-sm-none< / code > < / td >
< / tr >
< tr >
< td > Visible only on sm< / td >
< td > < code > .d-none .d-sm-block .d-md-none< / code > < / td >
< / tr >
< tr >
< td > Visible only on md< / td >
< td > < code > .d-none .d-md-block .d-lg-none< / code > < / td >
< / tr >
< tr >
< td > Visible only on lg< / td >
< td > < code > .d-none .d-lg-block .d-xl-none< / code > < / td >
< / tr >
< tr >
< td > Visible only on xl< / td >
< td > < code > .d-none .d-xl-block< / code > < / td >
< / tr >
< / tbody >
< / table >
2017-09-07 00:10:32 +02:00
2019-01-08 17:33:28 +01:00
{{< example > }}
2019-05-29 17:17:40 +02:00
< div class = "d-lg-none" > hide on lg and wider screens< / div >
2017-10-18 23:28:09 +02:00
< div class = "d-none d-lg-block" > hide on screens smaller than lg< / div >
2019-01-08 17:33:28 +01:00
{{< / example > }}
2017-10-18 23:28:09 +02:00
2017-03-03 21:57:16 +01:00
## Display in print
2018-01-18 02:29:28 +01:00
Change the `display` value of elements when printing with our print display utility classes. Includes support for the same `display` values as our responsive `.d-*` utilities.
- `.d-print-none`
- `.d-print-inline`
- `.d-print-inline-block`
- `.d-print-block`
- `.d-print-table`
- `.d-print-table-row`
- `.d-print-table-cell`
- `.d-print-flex`
- `.d-print-inline-flex`
2017-10-18 23:28:09 +02:00
The print and display classes can be combined.
2019-01-08 17:33:28 +01:00
{{< example > }}
2017-10-19 22:14:08 +02:00
< div class = "d-print-none" > Screen Only (Hide on print only)< / div >
< div class = "d-none d-print-block" > Print Only (Hide on screen only)< / div >
< div class = "d-none d-lg-block d-print-block" > Hide up to large on screen, but always show on print< / div >
2019-01-08 17:33:28 +01:00
{{< / example > }}