useState和useEffect的使用问题

发布于 2022-09-12 03:50:11 字数 1777 浏览 16 评论 0

写了个自定义的数据请求hook

const useFetch = (method = "GET") => {
  const [res, setRes] = useState({});
  const [url, setUrl] = useState(null);
  const [loading, setLoading] = useState(false);
  const [error, setError] = useState(null);
  const firstUpdate = useRef(true);
  const sendFetch = (url) => {
    setUrl(getUrl(url));
  };
  useEffect(() => {
    (async () => {
      if (firstUpdate.current) return (firstUpdate.current = false);
      try {
        const options = {
          method,
          headers: { "Content-Type": "application/json;charset=utf-8" },
        };
        setLoading(true);
        const res = await fetch(url, options);
        const json = await res.json();
        setLoading(false);
        setRes(json.data || json);
      } catch (error) {
        setLoading(false);
        setError(error);
      }
    })();
    return () => {
      
    }
  }, [url]);
  return { sendFetch, res, loading, error };
};

然后在组件里使用:

const StartForm = props  => {
    const { sendFetch, res, loading } = useFetch();
    const [instockData, setInstockData] = useState({
        userId: '',
        fullName: '',
        unitCode: '',
    });
    useEffect(() => {
        sendFetch(`${url}?`);
    },[])
}

现在的问题就是:我想等res有数据了之后去setInstockData,所以我需要把res作为useEffect的依赖放到它的数组里。但是这样的话会导致死循环了,
然后我想使用useRef来让sendFetch只执行一次,但是感觉也麻烦,
最后我想再使用那个useLayoutHook来监听res的变化,然后去setInstockData,但是这样会导致页面闪烁。

    useLayoutEffect(() => {
        Object.keys(res).length && setInstockData({...instockData,...res})
    },[res])//这样会导致页面闪烁

有没有更好的办法呢。

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

初见你 2022-09-19 03:50:11

你在自定义的 useFetch() 中已经将 res 设定为了一个 state,按照你的逻辑 instockData 要依赖 res,此时完全可以直接使用res即可,无需再定义另外的 state (instockData) 了。
将 instockData 看成是一个派生状态,或者类似 vue 中计算属性一样去处理。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文