当前位置: 首页 > news >正文

React-Redux 中的useDispatch 用法

目录

useDispatch 的基本概念

主要用途

在我们的项目中的应用


useDispatch 的基本概念

useDispatch是一个 React Hook,它返回 Redux store 的 dispatch 函数的引用。通过这个函数,我们可以向 Redux store 发送 actions,从而更新应用程序的状态。

主要用途

  1. 触发 Redux actions:通过 useDispatch 获取 dispatch 函数,然后用它来 dispatch actions,更新 Redux store 中的状态。

  2. 连接 UI 与状态管理:允许组件通过 dispatching actions 来响应用户交互或其它事件。

在我们的项目中的应用

在 Login.tsx 组件中,我们这样使用了 useDispatch:

import React, { FC, useEffect } from 'react' import { useNavigate, Link } from 'react-router-dom' import { Typography, Space, Form, Input, Button, Checkbox, message } from 'antd' import { UserAddOutlined } from '@ant-design/icons' import { useDispatch } from 'react-redux' import { useRequest } from 'ahooks' import { REGISTER_PATHNAME, MANAGE_INDEX_PATHNAME } from '../router' import { loginService } from '../services/user' import { setToken } from '../utils/user-token' import { loginReducer } from '../store/userReducer' import styles from './Login.module.scss' const { Title } = Typography const USERNAME_KEY = 'USERNAME' const PASSWORD_KEY = 'PASSWORD' function rememberUser(username: string, password: string) { localStorage.setItem(USERNAME_KEY, username) localStorage.setItem(PASSWORD_KEY, password) } function deleteUserFromStorage() { localStorage.removeItem(USERNAME_KEY) localStorage.removeItem(PASSWORD_KEY) } function getUserInfoFromStorage() { return { username: localStorage.getItem(USERNAME_KEY), password: localStorage.getItem(PASSWORD_KEY), } } const Login: FC = () => { const nav = useNavigate() const dispatch = useDispatch() const [form] = Form.useForm() // 第三方 hook useEffect(() => { const { username, password } = getUserInfoFromStorage() form.setFieldsValue({ username, password }) }, []) const { run } = useRequest( async (username: string, password: string) => { const data = await loginService(username, password) return data }, { manual: true, onSuccess(result) { const { token = '', userInfo } = result setToken(token) // 存储 token // 主动将用户信息存入 Redux store const { username, nickname } = userInfo dispatch(loginReducer({ username, nickname })) message.success('登录成功') nav(MANAGE_INDEX_PATHNAME) // 导航到"我的问卷" }, } ) const onFinish = (values: any) => { const { username, password, remember } = values || {} run(username, password) // 执行 ajax if (remember) { rememberUser(username, password) } else { deleteUserFromStorage() } } return ( <div className={styles.container}> <div> <Space> <Title level={2}> <UserAddOutlined /> </Title> <Title level={2}>用户登录</Title> </Space> </div> <div> <Form labelCol={{ span: 6 }} wrapperCol={{ span: 16 }} initialValues={{ remember: true }} onFinish={onFinish} form={form} > <Form.Item label="用户名" name="username" rules={[ { required: true, message: '请输入用户名' }, { type: 'string', min: 5, max: 20, message: '字符长度在 5-20 之间' }, { pattern: /^\w+$/, message: '只能是字母数字下划线' }, ]} > <Input /> </Form.Item> <Form.Item label="密码" name="password" rules={[{ required: true, message: '请输入密码' }]} > <Input.Password /> </Form.Item> <Form.Item name="remember" valuePropName="checked" wrapperCol={{ offset: 6, span: 16 }}> <Checkbox {...({ children: '记住我' } as any)} /> </Form.Item> <Form.Item wrapperCol={{ offset: 6, span: 16 }}> <Space> <Button type="primary" htmlType="submit"> 登录 </Button> <Link to={REGISTER_PATHNAME}>注册新用户</Link> </Space> </Form.Item> </Form> </div> </div> ) } export default Login

在这段代码中,useDispatch 的作用是:
1. 获取 Redux store 的 dispatch 函数
2. 当登录成功后,主动调用 dispatch(loginReducer({ username, nickname })) 将用户信息存储到 Redux store 中
3. 这样在页面跳转后,目标页面就能立即从 Redux store 中获取到用户信息,而不需要等待异步请求
为什么需要这样做?
在我们之前的实现中,虽然登录成功并存储了 token,但在跳转到新页面时,目标页面需要通过 useLoadUserData 钩子来加载用户信息。这个钩子会检查 Redux store 中是否已经有用户信息:

// 判断当前 redux store 是否已经存在用户信息 const { username } = useGetUserInfo() // redux store useEffect(() => { if (username) { setWaitingUserData(false) // 如果 redux store 已经存在用户信息,就不用重新加载了 return } run() // 如果 redux store 中没有用户信息,则进行加载 }, [username])

如果我们不在登录成功后主动将用户信息存入 Redux,那么在跳转后,username 会是空的,导致 useLoadUserData 钩子发起 AJAX 请求去获取用户信息。由于浏览器的异步特性和可能的时序问题,这可能导致页面显示异常或者延迟。
通过使用 useDispatch 主动 dispatch 用户信息,我们确保了在跳转后,Redux store 中已经有正确的用户信息,避免了额外的网络请求和潜在的时序问题。

总结

useDispatch 是 React-Redux 中的关键 Hook,它使得函数组件能够与 Redux store 进行交互,通过 dispatching actions 来更新全局状态。在我们的案例中,它帮助我们解决了登录后跳转时的用户体验问题,确保用户信息能及时同步到 Redux store 中。

http://www.rkmt.cn/news/121250.html

相关文章:

  • 全网最强实测!知网检测AI率太高?手把手教你降低AI率,告别论文“AI味”! - 殷念写论文
  • 【轨迹优化】基于灵活最终时间约束微分动态规划FFT-CDDP导弹模型轨迹优化附Matlab代码
  • 2025年中央空调品牌耐用排行及性价比推荐,中央空调品牌哪个 - myqiye
  • 基于Kotaemon的智能心理咨询系统开发
  • Kotaemon能否导出问答记录?审计合规功能详解
  • 大厂Simulink仿真模型:同步电机死区补偿与自适应补偿研究
  • 基于 STM32 的图书馆座位智能管理系统设计与实现
  • 1.3 万亿市场格局:AIGC产业全景图大揭秘
  • Kotaemon是否支持私有化部署?安全策略全公开
  • 腾讯云RAG实践指南:从文档解析到多模态,大模型落地全链路拆解
  • [Web开发合集] 踏浪阿里巅峰之路 成为P6前端架构师的终极征程 80G深度探索31模块最新前沿技术潮流
  • Kotaemon支持Tekton流水线吗?CI/CD深度集成
  • 亚马逊大额采购自养号全攻略:轻松上手无担忧
  • Kotaemon能否识别音乐类型?音频元数据应用场景
  • 2025年东北三省及内蒙古中量元素冲施肥生产公司推荐 - mypinpai
  • 企业级智能问答系统怎么搭?Kotaemon给你答案
  • zz通过 Markdown 改进 RAG 文档处理
  • 【完整源码+数据集+部署教程】数码管定位系统源码分享[一条龙教学YOLOV8标注好的数据集一键训练_70+全套改进创新点发刊_Web前端展示]
  • 这些专业宠物美容学校竟都是优质品牌,速来了解!
  • 上海易顶信息科技服务水平怎么样?技术实力怎么样? - 工业推荐榜
  • 为什么越来越多开发者选择Kotaemon做知识检索?
  • 5小时整理60页《Google Agent指南》,不懂Agent的包教包会
  • 逼自己练完这 64 页!你的 AI Agent 开发水平直接起飞(建议收藏)
  • 43、深入理解自定义集合与迭代器
  • 2025年年终新疆旅行社推荐:聚焦纯玩体验与安全保障,专家严选5家高可靠性服务商案例剖析 - 品牌推荐
  • 面向企业构建定制生成式AI模型的铸造厂服务发布
  • 如何贡献代码到Kotaemon开源项目?开发者入门指南
  • 基于Kotaemon构建金融行业智能客服的真实案例分享
  • 2025哪个留学中介做英国好 - 留学品牌推荐官
  • 2025年江西五大口碑好的叛逆孩子成长学校推荐,看哪家实力强 - mypinpai