首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用material-table实现远程数据的乐观渲染?

如何使用material-table实现远程数据的乐观渲染?
EN

Stack Overflow用户
提问于 2019-04-19 02:52:07
回答 1查看 4.2K关注 0票数 2

我在应用程序中对数据表使用了库material-table。我将数据属性设置为使用来自this.state.data的数据,并且通过使用setState添加行将在我的表中更新。但是,在切换到远程数据之后,表在添加行之后不会更新。有没有其他方法可以通过远程数据来实现这一点?

代码语言:javascript
复制
import React, {Component} from "react";
import MaterialTable from "material-table";
import Add from "@material-ui/icons/Add";
import Clear from "@material-ui/icons/Clear";
import Check from "@material-ui/icons/Check";
import Edit from "@material-ui/icons/Edit";
import FirstPage from "@material-ui/icons/FirstPage";
import ChevronRight from "@material-ui/icons/ChevronRight";
import LastPage from "@material-ui/icons/LastPage";
import ChevronLeft from "@material-ui/icons/ChevronLeft";
import Search from "@material-ui/icons/Search";
import ReactDOM from "react-dom";

import "./styles.css";

class App extends Component {
  state = {
    data: []
  }
  render() {
  return (
    <MaterialTable
      columns={[
        {
          title: "Avatar",
          field: "avatar",
          render: rowData => (
            <img
              style={{ height: 36, borderRadius: "50%" }}
              src={rowData.avatar}
            />
          )
        },
        { title: "Id", field: "id" },
        { title: "First Name", field: "first_name" },
        { title: "Last Name", field: "last_name" }
      ]}
      icons={{
        Add: () => <Add />,
        Check: () => <Check />,
        Clear: () => <Clear />,
        Edit: () => <Edit />,
        FirstPage: () => <FirstPage />,
        NextPage: () => <ChevronRight />,
        LastPage: () => <LastPage />,
        PreviousPage: () => <ChevronLeft />,
        ResetSearch: () => <Clear />,
        Search: () => <Search />
      }}

      // If this is an array from state(ie. this.state.data) then it works.
      data={query =>
        new Promise((resolve, reject) => {
          let url = "https://reqres.in/api/users?";
          url += "per_page=" + query.pageSize;
          url += "&page=" + (query.page + 1);
          fetch(url)
            .then(response => response.json())
            .then(result => {
              resolve({
                data: result.data,
                page: result.page - 1,
                totalCount: result.total
              });
            });
        })
      }
      editable={{
        onRowAdd: newData =>
          new Promise((resolve, reject) => {
            setTimeout(() => {
              {
                const data = this.state.data;
                data.push(newData);
                this.setState({ data }, () => resolve());
              }
              resolve();
            }, 1000);
          })
      }}
      title="Remote Data Example"
    />
  )
    }
}
const rootElement = document.getElementById("root");
ReactDOM.render(<App />, rootElement);
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-04-19 03:13:57

有一个解决方案,就是调用物料表所有查询事件的管理函数

您可以创建一个对表的React引用。在那一刻你就可以访问这个函数了。如果需要,您可以使用它将值直接传递给函数。

步骤如下: 1-创建一个值并分配React.createRef() let tableRef=React.createRef()

2-将其分配给名为tableRef的材料表特性

tableRef={tableRef}

3-然后,当您需要更新表时,您可以调用函数onQueryChange()来清除任何参数。

tableRef.current.onQueryChange()

例如:

代码语言:javascript
复制
`async apiDelete(IDs) {
try {
  await Service.delete(IDs);
  this.state.tableRef.current.onQueryChange();
} catch (e) {
  console.log("Error Deleting" + e);
}

}`

你可以做其他的事情,比如:this.state.tableRef.current.onQueryChange({filters: "value"});

请创建一个console.log(tableRef)以查看您可以执行的所有操作。

如果这对你有帮助,请让我知道

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/55752163

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档