@vaadin/virtual-list
Version:
Web Component for displaying a virtual/infinite list of items.
68 lines (44 loc) • 1.97 kB
Markdown
# @vaadin/virtual-list
A web component for rendering a long list of items without sacrificing performance.
[Documentation + Live Demo ↗](https://vaadin.com/docs/latest/components/virtual-list)
[](https://www.npmjs.com/package/@vaadin/virtual-list)
```html
<vaadin-virtual-list></vaadin-virtual-list>
<script>
const list = document.querySelector('vaadin-virtual-list');
list.items = items; // An array of data items
list.renderer = (root, list, { item, index }) => {
root.textContent = `#${index}: ${item.name}`;
};
</script>
```
## Installation
Install the component:
```sh
npm i @vaadin/virtual-list
```
Once installed, import the component in your application:
```js
import '@vaadin/virtual-list';
```
## Themes
Vaadin components come with two built-in [themes](https://vaadin.com/docs/latest/styling), Lumo and Material.
The [main entrypoint](https://github.com/vaadin/web-components/blob/main/packages/virtual-list/vaadin-virtual-list.js) of the package uses the Lumo theme.
To use the Material theme, import the component from the `theme/material` folder:
```js
import '@vaadin/virtual-list/theme/material/vaadin-virtual-list.js';
```
You can also import the Lumo version of the component explicitly:
```js
import '@vaadin/virtual-list/theme/lumo/vaadin-virtual-list.js';
```
Finally, you can import the un-themed component from the `src` folder to get a minimal starting point:
```js
import '@vaadin/virtual-list/src/vaadin-virtual-list.js';
```
## Contributing
Read the [contributing guide](https://vaadin.com/docs/latest/contributing) to learn about our development process, how to propose bugfixes and improvements, and how to test your changes to Vaadin components.
## License
Apache License 2.0
Vaadin collects usage statistics at development time to improve this product.
For details and to opt-out, see https://github.com/vaadin/vaadin-usage-statistics.