不知道如何使用hooks在reduxstate中正确获取fetching结果
创始人
2025-01-12 06:00:10
0

假设我们的fetch请求包含以下三个状态:isLoading(是否正在加载),error(加载过程中发生的错误)和data(加载成功后返回的数据)。

我们可以使用useSelector自定义hooks从redux store中获取这些状态:

import { useSelector } from 'react-redux';

const useFetchData = () => {
  const isLoading = useSelector(state => state.fetch.isLoading);
  const error = useSelector(state => state.fetch.error);
  const data = useSelector(state => state.fetch.data);
  return { isLoading, error, data };
};

在我们的函数组件中,我们可以轻松地调用useFetchData并获取我们需要的状态:

import React from 'react';
import { useDispatch } from 'react-redux';
import { fetchData } from './actions';
import useFetchData from './useFetchData';

const MyComponent = () => {
  const { isLoading, error, data } = useFetchData();
  const dispatch = useDispatch();

  const handleClick = () => {
    dispatch(fetchData());
  };

  if (isLoading) {
    return 
Loading...
; } if (error) { return
{error.message}
; } return (
{data.map(item => (
{item.name}
))}
); }; export default MyComponent;

这里我们将isLoading,error和data分别从useFetchData自定义hook中拆分出来,使我们可以更清楚地了解我们需要的每个状态。

在MyComponent函数组件中,我们添加了一个按钮,用于手动获取数据。当isLoading为true时,显示“正在加载”,当error存在时,显示错误消息,否则将渲染数据列表。

这是一种简单而有效的方式,可以使用hooks从redux store中正确获取fetching状态。

相关内容

热门资讯

一秒答解"斗棋bug... 一秒答解"斗棋bug"开挂(透视)wejoker辅助软件(有挂解惑)wejoker辅助软件ai黑科技...
通报开挂!wepoker透视功... 通报开挂!wepoker透视功能下载,微乐河南麻将辅助ios,(透视)曝光教程(有挂存在) >>您好...
透视透视"雀友会潮汕... 您好:德普之星私人局辅助免费这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现很多用...
必看辅助!wepoker透视辅... 必看辅助!wepoker透视辅助下载,德州局怎么透视,(透视)透明挂教程(真实有挂)《详细加薇136...
玩家必备科普"微信老... wepoker辅助透视软件是一款专注玩家量身打造的游戏记牌类型软件,在wepoker辅助透视软件这款...
盘点辅助!wepoker透视脚... 您好:wepoker透视脚本是什么这款游戏可以开挂的,确实是有挂的,很多玩家在这款游戏中打牌都会发现...
最新技巧"sohoo... 最新技巧"sohoo开挂辅助"开挂(透视)wpk辅助插件(有挂秘籍);无需打开直接搜索微信(1367...
传授透视!hhpoker哪个俱... 传授透视!hhpoker哪个俱乐部靠谱,钱塘十水三插件,(透视)介绍教程(有挂透视)这是一款可以让一...
盘点一款"哈局八张透... 盘点一款"哈局八张透视辅助"开挂(透视)aapoker万能辅助器(有挂解密)1、下载安装好哈局八张透...
盘点透视!aapoker怎么拿... 大家好,今天小编来为大家解答威信茶馆有挂的吗这个问题咨询软件客服可以免费测试直接加微信(136704...