【发布时间】:2021-09-13 23:11:27
【问题描述】:
我们在获取数据数组时使用了 useMemo 和 useEffect。在第一个文件中,我设置了一个带有挂钩结果的 const(第二个文件)。但是结果被设置了两次,第一次结果是一个空对象。
我需要在 useEffect 完成工作后设置它。
我们有 2 个 js 文件
- first.js
- second.js
First.js
const dataArray = useGetDataArray({ name, id });
console.log("Data Array: ", dataArray);
Second.js
export const useGetDatArray = ({ name, id } = {}) => {
const [data, setData] = useState({});
const index = useMemo(() => {
console.log("in useMemo");
const client = thirdPartyProvider;
return client;
}, []);
useEffect(() => {
console.log("in useEffect");
index
.search(name, {
numberOfResults: 12,
})
.then(res => setData(_.get(res, "result")));
}, [index]);
return data;
};
我的控制台是这样的
"in useMemo "
"Data Array:" Object { }
"in useEffect"
"Data Array:" Array(12) [ {…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, … ]
如果可能的话,这就是我想要的方式
"in useMemo"
"in useEffect"
"Data Array:" Array(12) [ {…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, {…}, … ]
【问题讨论】:
-
你不能。每次更改状态时都会进行渲染。我还建议将初始值设置为数组。
-
在useEffect中添加依赖?
-
@evolutionxbox 这就是我所害怕的。
-
@RicardodePaula 我有一个依赖,索引变量
标签: javascript react-hooks use-effect react-usememo