javascript - 自定义加载器不适用于 react-table

标签 javascript reactjs typescript semantic-ui-react react-table

我正在尝试使用语义 ui-react 提供的 Spinner 覆盖 react-table 提供的默认加载器。但这似乎行不通。我维护了三个组件;一个是 App,一个用于 Data Grid,另一个用于 Spinner。有人可以在这里帮助我吗?
沙盒:https://codesandbox.io/s/react-table-row-table-g3kd5
应用组件

import * as React from "react";
import { render } from "react-dom";
import DataGrid from "./DataGrid";

class App extends React.Component {
  constructor(props) {
    super(props);
    this.state = {
      data: [],
      columns: [],
      loading: true
    };
  }

  componentDidMount() {
    this.getData();
    this.getColumns();
  }

  getData = () => {
    let data = [
      { firstName: "Jack", status: "Submitted" },
      { firstName: "Simon", status: "Pending" },
      { firstName: "Pete", status: "Approved" }
    ];
    setTimeout(() => {
      this.setState({ data, loading: false });
    }, 2000);
  };

  getColumns = () => {
    let columns = [
      {
        Header: "First Name",
        accessor: "firstName"
      },
      {
        Header: "Status",
        accessor: "status"
      }
    ];
    this.setState({ columns });
  };

  render() {
    return (
      <>
        <DataGrid
          loading={this.state.loading}
          data={this.state.data}
          columns={this.state.columns}
        />
      </>
    );
  }
}


数据网格
import * as React from "react";
import ReactTable from "react-table";
import "react-table/react-table.css";
import Spinner from "./Spinner";


export default class DataGrid extends React.Component {
  render() {
    return (
      <>
        <ReactTable
          loading={this.props.loading}
          data={this.props.data}
          LoadingComponent={Spinner}
          columns={this.props.columns}
        />
      </>
    );
  }
}


微调器
import { Loader } from "semantic-ui-react";
import * as React from "react";

const Spinner: React.FunctionComponent = props => {
  return (
    <div>
      <Loader active={props.spinnerFlag}>Loading</Loader>
    </div>
  );
};

export default Spinner;

最佳答案

好吧,你错过了一些东西。

首先,如果你检查你的沙箱,它确实会在最后显示加载,但有一个问题。
你需要做两件事

1- 为您的 Spinner 提供适当的样式,使其出现在您的表格上而不是下方。

2-您需要利用您传递给 ReactTable 组件的加载 Prop 。因为现在你的 Spinner 总是可见的,它不受加载 Prop 的控制

您的微调器组件应该使用 props.loading 而不是 props.spinnerFlag 因为这是传递给 ReactTable 组件的内容

将您的 Spinner 文件更改为这样

const Spinner: React.FunctionComponent<IProps> = props => {
return props.loading ? (
<div
  style={{
    display: "block",
    position: "absolute",
    left: 0,
    right: 0,
    background: "rgba(255,255,255,0.8)",
    transition: "all .3s ease",
    top: 0,
    bottom: 0,
    textAlign: "center"
  }}
>
  <Loader>Loading</Loader>
</div>
) : null;
};

export default Spinner;

现在你应该可以看到你的加载器了。
这里是 Sandbox

希望这可以帮助

关于javascript - 自定义加载器不适用于 react-table,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58181976/

相关文章:

css - 如何将字体添加到基于 create-react-app 的元素?

reactjs - 为什么在枚举中类型没有重叠?

typescript - Observable 中的 observer.throw 和 observer.error 有什么区别?

javascript - 我们可以从 typescript 代码更改图像源吗?

javascript - 在 prestashop 中使用 jquery 进行翻译

JavaScript 文件包含。我不应该在 <head> 中链接吗?

javascript - 如何在 React 中传递带有事件处理函数的 Prop ?

reactjs - 使用渲染外部的堆栈导航访问 channel 数据

javascript - 按短语搜索 html 元素

javascript - 新窗口,内容来自开启页面上的模态内容