Aspect Ratio
The Aspect Ratio component shapes the content with the specified ratio.
The default aspect ratio implementation combines height: 0px
with percentage padding-bottom to create the proper aspect ratio for the content.
(It will be replaced by the CSS aspect-ratio in the future once it has sufficient browser support).
- The content to fit the area of the aspect ratio component must be its first direct child.
- It's designed to be composed with other components, e.g.
Card
.
Basic usage
The default aspect ratio is 16/9
.
16 : 9
Ratio
Use the ratio
prop to change the aspect ratio.
The value will used by the CSS calc()
.
4 : 3
Media
Place a native html <img>
or <video>
as a first direct child of the aspect ratio component.
Use the objectFit
prop to change how the media should be resized in order to fit the aspect ratio component.
It has object-fit: cover
by default.
An example of using contain
value
Controlling the height
Use minHeight
and maxHeight
to set the lower and upper bound of the component's height.
This is useful when the aspect ratio is used in a component that has dynamic width.
Inside a flex row
When the aspect ratio component is placed as a child of a flexbox row
container, use flex-basis
to set the ideal width of the aspect ratio.
Yosemite National Park
California, USA
Common examples
Mobile Carousel
Make sure to keep your content concise given the limited width real estate available.
Since the texts are short, we can set white-space: nowrap
to make the title stay in one line.
The min-width
CSS property is necessary on the aspect ratio component to prevent it from shrinking to zero.
Night view
4.21M views
Lake view
4.74M views
Mountain view
3.98M views
Night view
4.21M views
Lake view
4.74M views
Mountain view
3.98M views