1

我在手动重置页面索引时遇到问题

我手动处理来自onPageChangeonPageSizeChange...等的数据更改

当我使用onPageChange存储在高级组件中的页面索引更改页面索引并再次将 ReactTable 作为称为 currentPage 的道具传递时,我需要将 currentPage 重置为 0 ,但剂量有效,因此我添加了componentDidUpdate回调以强制重置页面索引

ReactTable 版本 6.11.5

componentDidUpdate(prevProps, prevState) {
    const reactTable = this.myRef.current;
    const { currentPage } = this.props;
    if (reactTable && currentPage !== reactTable.state.page) {
      reactTable.state.page = currentPage;
      reactTable.getResolvedState().page = currentPage;
    }
  }

render() {
    const {
      data,
      loading,
      totalNumberOfPages,
      currentPage,
      onPageChange,
      pageSize,
      onPageSizeChange,
      onFilteredChange,
      onSortedChange,
      filtered,
    } = this.props;
 return (<ReactTable
            ref={this.myRef}
            filtered={filtered}
            onFilteredChange={(filtered) => {
              onFilteredChange(filtered);
              this.setState({ filtered });
            }}
            manual
            sorted={tableSorted}
            onSortedChange={(sorted) => onSortedChange(sorted)}
            filterable
            loading={loading && !silentUpdate}
            pages={totalNumberOfPages}
            page={currentPage}
            onPageChange={onPageChange}
            defaultPageSize={pageSize}
            pageSize={pageSize}
            onPageSizeChange={onPageSizeChange}
            loadingText="Loading..."
            data={data}
            columns={columns}
            className="-striped -highlight"
        />)

代码沙盒

https://codesandbox.io/s/set-initial-page-number-in-react-table-jthci?file=/App.js

如果您在第 3 页并按“重置页面”,它应该在第一页

4

1 回答 1

3

我创建了一个小代码沙盒问题来向您展示它正在工作。检查此链接

https://codesandbox.io/s/set-initial-page-number-in-react-table-mumef

所以,通过阅读源代码react-table,我看到用于分页的组件被称为ReactTablePagination

该组件具有以下行

{showPageJump ? renderPageJump(this.getPageJumpProperties()) : renderCurrentPage(page)}{' '}

这意味着为了更新页面索引,此属性showPageJump应设置为false.

我尝试不设置所有这些属性,但它不起作用。当我将其设置为 false 时,它​​起作用了。

于 2020-08-05T17:32:21.733 回答