不知道如何使用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状态。

相关内容

热门资讯

黑科技插件!微乐小程序免费黑科... 黑科技插件!微乐小程序免费黑科技,微信小程序微乐辅助器脚本(透视)总是是有辅助插件(哔哩哔哩)所有人...
透视绝活儿!wpk俱乐部有没有... 透视绝活儿!wpk俱乐部有没有辅助(WePoKer软件)真是有辅助工具(哔哩哔哩)1、wpk俱乐部有...
透视好友房!微乐小程序黑科技,... 透视好友房!微乐小程序黑科技,微乐智能插件激活码(透视)本来是真的辅助技巧(哔哩哔哩)暗藏猫腻,小编...
透视方针!hhpoker脚本(... 透视方针!hhpoker脚本(WePoKer脚本)真是真的是有辅助方法(哔哩哔哩)该软件可以轻松地帮...
辅助透视!微乐小程序黑科技免费... 辅助透视!微乐小程序黑科技免费,微信微乐自建房脚本免费下载(透视)其实是真的辅助app(哔哩哔哩)所...
透视法子!wepoker有没有... 透视法子!wepoker有没有辅助(HHpoker透视挂)竟然真的是有辅助工具(哔哩哔哩)1)wep...
透视模拟器!微信微乐游戏辅助脚... 透视模拟器!微信微乐游戏辅助脚本,微乐自建房辅助入口官网(透视)好像是真的辅助器(哔哩哔哩)1、下载...
透视模块!pokemomo辅助... 透视模块!pokemomo辅助工具(WePoKer机器人)一贯是真的有辅助神器(哔哩哔哩)pokem...
透视ai!微乐小程序黑科技,微... 透视ai!微乐小程序黑科技,微乐自建房插件免费软件(透视)好像是有辅助工具(哔哩哔哩)该软件可以轻松...
透视秘籍!hhpoker有没有... 透视秘籍!hhpoker有没有作必弊挂(WePoKer规律)一直是真的有辅助技巧(哔哩哔哩);1、全...