Ame*_*kar 3 reactjs react-hooks material-table
我正在尝试使用反应钩子编辑/删除材料表中的一行。虽然我可以看到状态正在被修改,但它并没有重新渲染材质表。在 setdata 之后 useeffect 不会触发。
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;
Run Code Online (Sandbox Code Playgroud)
上面的代码最初渲染得很好。但是,当我尝试删除该行时,数据已删除了一行,但 useEffect 不会触发并且 MaterialTable 组件不会使用新数据呈现。但是,如果我使用注释掉的代码,则删除后 useEffect 会很好地触发。我错过了什么?
你不应该改变你的数据来触发 useEffect 钩子或使用 props 和 state 来反应一般。问题是,您将相同的对象设置为状态挂钩,只是发生了变异。对象引用是相同的,useEffect 将假定没有任何更改。像这样写:
new Promise((resolve, reject) => {
setTimeout(() => {
setData(data.filter(row => row._id !== oldData ._id);
resolve();
}, 1000);
})
Run Code Online (Sandbox Code Playgroud)
过滤器将返回一个新数组,但所选项目将被删除。现在数据是一个新数组,这将触发 useEffect 钩子,因为旧对象和新对象的引用不同。
_.remove(data, row => row._id !== 3)) 也返回一个新的数组,如 filter 更新钩子不可变的。这将触发 useEffect 钩子并导致重新渲染。希望这可以帮助。快乐编码。
| 归档时间: |
|
| 查看次数: |
4333 次 |
| 最近记录: |