【问题标题】:How can i wait for a value to be set from useEffect?我如何等待从 useEffect 设置值?
【发布时间】: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


【解决方案1】:

First.js

useEffect(async () => {
  await useGetDataArray({ name, id });
  const dataArray = myContainer.data;
  console.log("Data Array: ", dataArray);
}, []);

Second.js

export const useGetDatArray = ({ name, id } = {}) => {
  const index = useMemo(() => {
    console.log("in useMemo");
    const client = thirdPartyProvider;

    return client;
  }, []);

  useEffect(async () => {
    console.log("in useEffect");
    await myContainer.getData(index, name);
  }, [index]);
};

容器.js

function myContainer(){
  const [data, setData] = useState({});

  const getData = async (index, name) => {
    const indexData = await index.search(name, { numberOfResults: 12 });
    if (indexData) {
        await setData(indexData);
    }
  }

  return { data, getData };
}
export const MyContainer = createContainer(myContainer);

【讨论】:

  • Data Array 仍然会先被调用,没有答案,因为你不应该等待钩子
猜你喜欢
  • 2021-09-15
  • 2020-07-29
  • 2021-03-21
  • 2022-01-02
  • 1970-01-01
  • 1970-01-01
  • 2021-08-10
  • 2020-12-03
  • 2021-11-23
相关资源
最近更新 更多