reactjs - 使用钩子(Hook)编辑 React Material 表

标签 reactjs react-hooks material-table

我正在尝试使用 React Hooks 编辑/删除 Material 表中的一行。虽然我可以看到状态正在被修改,但它并没有重新渲染 Material 表。 useEffect 在 setdata 之后没有触发。

import React, { useState, useEffect } from "react";
import faker from "faker";
import MaterialTable from "material-table";
import * as _ from "lodash";

let testData = [];

for (var i = 0; i < 100; i++) {
    testData.push({
        _id: i,
        fullName: faker.name.findName(),
        "email.address": faker.internet.email(),
        phone_number: faker.phone.phoneNumber(),
        address: {
            city: faker.address.city(),
            state: faker.address.state(),
            country: faker.address.country()
        }
    });
}

let columndata = [
    { title: "Id", field: "_id" },
    { title: "Name", field: "fullName" },
    { title: "Email", field: "email.address" },
    { title: "Phone", field: "phone_number" },
    { title: "City", field: "address.city" },
    { title: "State", field: "address.state" },
    { title: "Country", field: "address.country" }
];

const MyDataGrid = () => {
    let [data, setData] = useState(testData);

    useEffect(() => {
        debugger;
        if (data.length < 100) {
            console.log(data.length);
        }
    }, [data]);

    return (
        <MaterialTable
            columns={columndata}
            data={data}
            title="test-table"
            options={{
                filtering: true,
                sorting: true,
                exportButton: true,
                grouping: true
            }}
            editable={{
                onRowDelete: oldData =>
                    new Promise((resolve, reject) => {
                        setTimeout(() => {
                            let newData = data;
                            _.remove(newData, { _id: oldData._id });
                            debugger;
                            setData(newData);
                            resolve();
                        }, 1000);
                    })
            }}
        />
        // <button onClick={() => setData(_.remove(data, row => row._id !== 3))}>
        //     Click me
        // </button>
    );
};

export default MyDataGrid;

上面的代码最初呈现良好。但是,当我尝试删除该行时,数据已删除一行,但 useEffect 不会触发,并且 MaterialTable 组件不会使用新数据呈现。但是,如果我使用注释掉的代码,则 useEffect 在删除后会正常触发。我错过了什么?

最佳答案

你不应该改变你的数据来触发 useEffect 钩子(Hook)或者在一般情况下使用 props 和 state。问题是,你将同一个对象设置到你的状态 Hook ,只是发生了变化。对象引用是相同的,useEffect 将假定没有任何改变。像这样写:

new Promise((resolve, reject) => {
                    setTimeout(() => {
                        setData(data.filter(row => row._id !== oldData ._id);
                        resolve();
                    }, 1000);
                })

过滤器将返回一个新数组,但所选项目将被删除。现在数据是一个新数组,这将触发 useEffect 钩子(Hook),因为新旧对象的引用不同。

_.remove(data, row => row._id !== 3)) 也返回一个新的数组,比如更新钩子(Hook)不可变的过滤器。这将触发 useEffect Hook 并导致重新渲染。 希望这可以帮助。快乐编码。

关于reactjs - 使用钩子(Hook)编辑 React Material 表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57355808/

相关文章:

javascript - 对空数组调用 .find() 会导致错误

reactjs - 我想在项目的类组件中使用 i18next 但出现此错误

javascript - 当数组作为依赖项传递时,React 中的 useEffect 会在无限循环中运行

reactjs - Material 表如何选择一行在选择时更改背景颜色

javascript - Action 图标显示为纯文本

javascript - Redux - 在操作或 reducer 中调用函数链?

javascript - React 中的渲染方法触发 2 次

javascript - 如何使 Material ui dropzone 区域不允许重复?

reactjs - GraphQL Apollo React Hooks 查询根据初始化顺序返回 null

reactjs - React Material 表列可调整大小