javascript - 我怎样才能重新渲染 Ant 表

标签 javascript reactjs react-native react-redux antd

我使用 ant desing 中的表。我对更新状态时如何重新呈现表数据源有疑问?我将状态添加到数据源,如:

<Table
            rowKey="Id"
            columns={columns}
            dataSource={documents.Data}
            className="w-full"
          />

在我更新我的状态之后:

const UpdateDocument = (row) => {
    let fakeList = { ...documents };
    let item = fakeList.Data.find((x) => x.Id === row.Id);
    let index = fakeList.Data.indexOf(item);
    fakeList.Data[index] = row;
    setDocuments(fakeList); //I update my state here. 
  };

但它不会重新呈现表数据源。在我更新我的状态后,它不应该重新渲染吗?我哪里做错了?感谢回复!

最佳答案

您正在更新相同的引用,您需要渲染一个副本,否则您的组件将不会渲染。

基于您的 codesandbox 的工作示例:

import "./styles.css";
import React, { useState } from "react";
import { Button, Table } from "antd";

const fakeData = {
  Data: [
    {
      Name: "Test 1",
      isOpen: true
    },
    {
      Name: "Test 2",
      isOpen: true
    },
    {
      Name: "Test 3",
      isOpen: true
    },
    {
      Name: "Test 4",
      isOpen: true
    }
  ]
};
export default function App() {
  const [newData, setnewData] = useState(fakeData);

  const changeState = () => {
    const fakeItem = { Name: "Fake test", isOpen: true };
    const newList = { Data: []};
    const datas = fakeData.Data.map((data) =>
      data.Name === "Test 3" ? fakeItem : data
    );
    newList.Data = datas;
    setnewData(newList);
  };
  const columns = [
    {
      title: "Name",
      dataIndex: "Name",
      key: "name"
    }
  ];

  return (
    <div className="App">
      <h1>Hello CodeSandbox</h1>
      <Table rowKey="Name" columns={columns} dataSource={newData.Data} />
      <Button onClick={changeState}>Change State</Button>
    </div>
  );
}

关于javascript - 我怎样才能重新渲染 Ant 表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/69140952/

相关文章:

javascript - 样式表未加载,因为 MIME 类型为 text/html

javascript - 是否每次需要 token 时都需要调用 acquireTokenSilent?

javascript - 如何滚动已定义最大高度的底部容器?

javascript - IE8 提示 Prototype, "' undefined' 为 null 或不是对象”

javascript - 在另一个 HTML 元素中将标题属性显示为字符串

reactjs - 如何更改 react 导航中的后退按钮路线

javascript - React/Router/MemoryRouter - 如何传递历史属性并在子组件中使用 push()?

java - 如果没有 'retrolambda' 语法,我该如何编写?

javascript - 使用 React 的嵌套列表

Javascript:如果 jquery GET 失败则更改 CSS 元素