虚拟滚动
ion-virtual-scroll?ion-virtual-scroll 已在 v6.0.0 中被弃用,并在 v7.0.0 中被移除。我们建议使用下面介绍的 Virtuoso 包。
对于 Ionic React 应用程序,一个值得考虑的虚拟滚动解决方案是 Virtuoso。本指南将介绍如何在你的 Ionic React 应用 程序中安装 Virtuoso,并与其他 Ionic 组件一起使用。
安装
要设置虚拟滚动器,首先安装 react-virtuoso:
npm install react-virtuoso
使用方法
Virtuoso 包含几个组件,但本示例将使用 Virtuoso 组件。该组件应添加到你的 IonContent 组件内部:
import React from 'react';
import { Virtuoso } from 'react-virtuoso';
import { IonAvatar, IonContent, IonItem, IonLabel, IonPage } from '@ionic/react';
const Home: React.FC = () => (
<IonPage>
<IonContent>
<Virtuoso
style={{ height: '100%' }}
totalCount={100}
itemContent={(index) => {
return (
<div style={{ height: '56px' }}>
<IonItem>
<IonAvatar slot="start">
<img src="https://picsum.photos/seed/picsum/40/40" />
</IonAvatar>
<IonLabel>{index}</IonLabel>
</IonItem>
</div>
);
}}
/>
</IonContent>
</IonPage>
);
export default Home;
将 Virtuoso 组件添加到我们的页面后,我们需要定义虚拟滚动容器的大小。在这种情况下,我们希望容器占据屏幕的整个高度,可以通过添加 style={{ height: '100%' }} 来实现。
接下来,我们希望通过 totalCount 属性定义要渲染的项目总数。
然后,我们可以使用 itemContent 属性传递一个函数,该函数将被调用来渲染虚拟滚动内容中的每个项目。
这里需要注意的一个重要点是包装 IonItem 组件的 div。当惰性加载 Ionic 组件时,可能会出现组件已加载但样式尚未加载的情况。发生这种情况时,组件的尺寸将为 0,Virtuoso 可能会抛出错误。这是因为 Virtuoso 需要为其渲染的每个项目提供明确的定位,而当组件尺寸为 0 时,它无法确定这一点。
与 Ionic 组件一起使用
Ionic Framework 要求某些功能(如可折叠大标题、ion-infinite-scroll、ion-refresher 和 ion-reorder-group)必须在 ion-content 内使用。要在虚拟 滚动中使用这些功能,你必须将 .ion-content-scroll-host 类添加到虚拟滚动视口。
例如:
<IonPage>
<IonContent scrollY={false}>
<Virtuoso className="ion-content-scroll-host">{/* 你的现有内容和配置 */}</Virtuoso>
</IonContent>
</IonPage>
进一步阅读
本指南仅涵盖了 Virtuoso 功能的一小部分。更多详细信息,请参阅 Virtuoso 文档。