我在使用自定义行渲染器处理 react 虚拟化表(在 AutoSizer 内的 InfiniteLoader 内)时遇到问题。呈现标题行,但没有数据行。 rowRenderer
或 rowGetter
甚至都不会被任何行调用。我检查了数据是否存在( this.props.requests
)。
我错过了什么,或者,我该如何进行调试?
<AutoSizer>
{({ height, width }) => (
<InfiniteLoader
isRowLoaded={this.isRowLoaded}
loadMoreRows={this.props.loadMoreEntries}
rowCount={(this.props.requests || []).length}
>
{({ onRowsRendered, registerChild }) => (
<Table
deferredMeasurementCache={this._cache}
onRowsRendered={onRowsRendered}
overscanRowCount={2}
ref={registerChild}
height={height}
headerHeight={50}
rowCount={(this.props.requests || []).length}
rowHeight={this._cache.rowHeight}
rowRenderer={this._rowRenderer}
rowGetter={this._rowGetter}
onRowClick={this.rowClicked}
width={width}
>
<Column
dataKey="requestType"
label="RqType"
width={100}
cellRenderer={this._renderRequestType}
/>
...
</Table>
)}
</InfiniteLoader>
)}
</AutoSizer>
最佳答案
我的猜测是容器 div 没有固定高度,并且由于您使用的是 Autosizer
,因此您的表格最终高度 = 0。尝试在 height
的 Prop 和容器 div 中使用固定的 Table
(可能基于当前行数 * 行高)。
您还可以检查 rowCount
是否为正值,但据我所知应该没问题。
关于reactjs - react-virtualized 中的表不呈现任何行,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/46133191/