Virtual Scroll
One virtual scrolling solution to consider for your Ionic React app is Virtuoso. This guide will go over how to install Virtuoso
into your Ionic React application and use it with other Ionic components.
#
InstallationTo setup the virtual scroller, first install react-virtuoso
:
#
UsageThere are a few components that Virtuoso includes, but this example will use the Virtuoso
component. This component should be added inside of your IonContent
component:
After adding the Virtuoso
component to our page, we need to define the size of the virtual scroll container. In this case, we want the container to take up the full height of the screen which we can do by adding style={{ height: '100%' }}
.
Next, we want to define the total number of items to render via the totalCount
property.
From there, we can use the itemContent
property to pass a function that will be called to render each item in our virtual scroll content.
An important thing to note here is the div
that wraps our IonItem
component. When lazy loading Ionic components, there may be a few frames where the component is loaded but the styles have not loaded in. When this happens, the component's dimension will be 0
, and Virtuoso may throw an error. This is because Virtuoso needs distinct positions for each item it renders, and it cannot determine that when a component's dimension is 0
.
#
A Note on Ionic ComponentsCertain Ionic Framework functionality is currently not compatible with virtual scrolling. Features such as collapsible large titles, ion-infinite-scroll
, and ion-refresher
rely on being able to scroll on ion-content
itself, and as a result will not work when using virtual scrolling.
We are working to improve compatibility between these components and virtual scrolling solutions. You can follow progress and give feedback here: https://github.com/ionic-team/ionic-framework/issues/23437.
#
Further ReadingThis guide only covers a small portion of what Virtuoso
is capable of. For more details, please see the Virtuoso documentation.