我在使用自定义行渲染器处理 react 虚拟化表(在 AutoSizer 内的 InfiniteLoader 内)时遇到问题。呈现标题行,但没有数据行。 rowRendererrowGetter 甚至都不会被任何行调用。我检查了数据是否存在( 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/

10-09 02:05