虚拟滚动
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 文档