The content-visibility
CSS property controls whether or not an element renders its contents at all, along with forcing a strong set of containments, allowing user agents to potentially omit large swathes of layout and rendering work until it becomes needed. Basically it enables the user agent to skip an element's rendering work, including layout and painting, until it is needed, makes the initial page load much faster.
Syntax
/* Keyword values */
content-visibility: visible;
content-visibility: hidden;
content-visibility: auto;
/* Global values */
content-visibility: initial;
content-visibility: unset;
Values
visible
- No effect. The element’s contents are laid out and rendered as normal.
hidden
- The element skips its contents. The skipped contents must not be accessible to user-agent features, such as find-in-page, tab-order navigation, etc., nor be selectable or focusable. This is similar to giving the contents
display: none
. auto
- The element turns on layout containment, style containment, and paint containment. If the element is not relevant to the user, it also skips its contents. Unlike hidden, the skipped contents must still be available as normal to user-agent features such as find-in-page, tab order navigation, etc., and must be focusable and selectable as normal.
Examples
Using auto to reduce rendering cost of long pages
The following example shows the use of auto to skip painting and rendering of off-screen sections. This helps with both load and interactions on the page, since the content outside of the viewport is not rendered.
<style>
section {
content-visibility: auto;
contain-intrinsic-size: 0 500px;
}
<section>...
<section>...
<section>...
<section>...
...
The following example shows that it is possible to manage visibility in script. The added benefit of using content-visiblity: hidden
instead of, for example, display: none
is that rendered content when hidden with content-visibility
will preserve rendering state. This means that if the content is shown again, it will render quicker than the alternative.
<style>
.hidden {
content-visibility: hidden;
/* when hidden, we want the element to size as if it had one child of 0x500px size */
contain-intrinsic-size: 0 500px;
}
.visible {
content-visibility: visible;
/* this is here to avoid layout shift when switching between .hidden and .visible */
contain: style layout paint;
}
<div class=hidden>...
<div class=visible>...
<div class=hidden>...
<div class=hidden>...
Specifications
Specification | Status | Comment |
---|---|---|
CSS Containment Module Level 2 | Working Draft | Initial definition |
Browser compatibility
The compatibility table in this page is generated from structured data. If you'd like to contribute to the data, please check out https://github.com/mdn/browser-compat-data and send us a pull request.
Update compatibility data on GitHub
Desktop | Mobile | |||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|
|
Chrome
Full support 85 |
Edge
Full support 85 |
Firefox
No support No |
IE
No support No |
Opera
Full support 71 |
Safari
No support No |
WebView Android
Full support 85 |
Chrome Android
Full support 85 |
Firefox Android
No support No |
Opera Android
Full support 60 |
Safari iOS
No support No |
Samsung Internet Android
No support No |
Legend
- Full support
- Full support
- No support
- No support
- Experimental. Expect behavior to change in the future.'
- Experimental. Expect behavior to change in the future.
See Also
content-visibility by Mozilla Contributors is licensed under CC-BY-SA 2.5.