Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/lbrian/content-visibility
Web Component uses CSS content-visibility and fallback Intersection Observer
https://github.com/lbrian/content-visibility
css intersection-observer intersectionobserver-api javascript lit-element lit-html typescript webcomponent webcomponents
Last synced: about 22 hours ago
JSON representation
Web Component uses CSS content-visibility and fallback Intersection Observer
- Host: GitHub
- URL: https://github.com/lbrian/content-visibility
- Owner: LBrian
- License: mit
- Created: 2021-01-04T12:14:58.000Z (about 4 years ago)
- Default Branch: master
- Last Pushed: 2023-03-05T18:43:35.000Z (almost 2 years ago)
- Last Synced: 2025-02-20T14:51:57.433Z (about 23 hours ago)
- Topics: css, intersection-observer, intersectionobserver-api, javascript, lit-element, lit-html, typescript, webcomponent, webcomponents
- Language: HTML
- Homepage:
- Size: 34.5 MB
- Stars: 28
- Watchers: 4
- Forks: 2
- Open Issues: 16
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# content-visibility
[data:image/s3,"s3://crabby-images/255be/255be3c21fecf9431ef6b053c6759fbee315e0ef" alt="Published on webcomponents.org"](https://www.webcomponents.org/element/content-visibility)
data:image/s3,"s3://crabby-images/0f9ca/0f9caa33e7b321f89c614c75187b0619f21620e4" alt="npm 7.0.15"
data:image/s3,"s3://crabby-images/02bb6/02bb639895037274d019aff14ed43216f057756e" alt="Typescript"
data:image/s3,"s3://crabby-images/93ae1/93ae1fbcc79c19f22d19cc3514ead3fae7e0da75" alt="Lit-Element"`` is a simple **web component** encapsulates modern CSS properties `content-visibility` and Web API **Intersection Observer API** to provide cross-browsers solution to skip rendering (layout & painting) elements until it is needed (appears on the viewport) to boosts page performance.
CSS `content-visibility` is only supported on Chrome 85+, Chrome Android 85+ and Opera 71+ but not Firefox, Safari and IE unfortunately, see [web.dev](https://web.dev/content-visibility/). **Intersection Observer API** supports pretty much all browsers except **IE**, thus an intersection observer [polyfill](https://www.npmjs.com/package/intersection-observer) is included for compatible on IE.
Basically, all children inside it will only be renderred after it appears on viewport.
```html
{children will not be rendered when outside the first viewport}
```
## Compatibility
![]()
![]()
![]()
![]()
![]()
![]()
# Getting started
## Install
`npm i content-visibility --save`
## Use in JSX (React/Preact)
```jsx
import 'content-visibility';const Content = () => {
return (
...
...
...
);
};
```## properties
### `containIntrinsicSize`
This is will be set as CSS custom variable for `contain-intrinsic-size` if browsers support it. [see](https://web.dev/content-visibility/#specifying-the-natural-size-of-an-element-with-contain-intrinsic-size)
```html
{children}
```
# Performance results
## Rendering frames
**Safari** comes with `Rendering Frames Timeline` tool helps to measure rendering performance. Let's have a look the rendering frames **without** ``, total `97` rendering frames happened on the first view.
data:image/s3,"s3://crabby-images/81755/817556c1d87881b05d482a5f9d6208326f079b44" alt="Rendering Frames - no content-visibility"Only `47` rendering frames happened on the first view after integrated with ``
data:image/s3,"s3://crabby-images/e1fc3/e1fc382782cd3d3902013c1121635070f1dd8529" alt="Rendering Frames - content-visibility"
the rest of `50` rendering frames happened when **scorlling to the viewport**
data:image/s3,"s3://crabby-images/42a7d/42a7dc954bcd5cafbf6dd0932f626a2c898e9631" alt="Rendering Frames - content-visibility scroll"## Rendering & Layout time
Generally speaking, we can plausibly say rendering & layout time improved around `40%`, however benchmark results vary depends on sampling size, environments, tools, implementation and etc. Too many factors could impact benchmark results, so this is just a quick sample results to demonstrate the performance differences.
### Chrome 87.0.4280.141
CSS `content-visibility` and `contain-intrinsic-size`
#### Before
data:image/s3,"s3://crabby-images/edf19/edf190ff27853788220c33bd394a62b055c05716" alt="Chrome Before"
#### After
**Rendering** and **Painting** time reduced around `50%`.
data:image/s3,"s3://crabby-images/2c1cf/2c1cf3fb8226df4db4e800582ba23d00ad6bc842" alt="Chrome After"
### Firefox 84.0.2
#### Before
data:image/s3,"s3://crabby-images/01544/01544601093a94877247ed94b101d5a3c819c05e" alt="Firefox Before"
#### After
data:image/s3,"s3://crabby-images/92486/92486c88613b6c0ab4ee0542b5789f672079f6d7" alt="Firefox After"
# License
Copyright (c) 2021 [Brian YP Liu](https://brianypliu.com/)