0

0

Redux 工具包:创建 Thunk 函数

花韻仙語

花韻仙語

发布时间:2024-12-23 14:46:10

|

885人浏览过

|

来源于dev.to

转载

什么是 thunk?

在编程中,thunk 一词指的是执行延迟工作的代码部分,例如 javascript 中的异步函数。

redux 存储本身不处理异步逻辑。它只知道如何:

  1. 同步调度动作。
  2. 通过减速器更新状态。
  3. 通知 ui 有关状态更改的信息。

但是等等,如果是这样的话,我们如何调用 api 并根据它们的响应更新状态,这通常需要时间?我们该如何处理?

这就是 thunk 函数的用武之地。

什么是 thunk 函数?

thunk 函数是为处理异步逻辑(例如调用 api)而创建的函数。它需要两个参数dispatch和getstate来调度动作,并在需要时访问当前状态。

const getallusers = () => {
  return async (dispatch, getstate) => {
    dispatch(fetingallusers());
    try {
      const users = await getusers();
      dispatch(userupdated(users));
    } catch (err) {
      dispatch(logerror(err))
    }
  }
}

返回的函数是 thunk 函数,getallusers 在本例中被称为 thunk 动作创建者,它将像这样调度:

dispatch(getallusers())

如果需要,可以使用 thunk 函数中使用的参数来调度 thunk 动作创建者。

使用 createasyncthunk 创建 thunk

redux toolkit 提供了 createasyncthunk api 来轻松生成 thunk:

wxPython 2.8 Application Development Cookbook英文pdf版
wxPython 2.8 Application Development Cookbook英文pdf版

在今天的桌面应用世界上有大量的奖励,以便能够开发应用程序,可以运行在多个环境。目前,有一种跨平台框架可供选择的Python开发桌面应用程序屈指可数。 wxPython的就是这样的一个跨平台的GUI工具包的Python编程语言。它允许Python程序员创建一个完整的,功能强大的图形用户界面的程序,简单,方便。 wxPython的代码风格,改变了多年来不少,并得到更多Python的。例子,你会发现这本书是对不断更新,反映在风格上的变化。 本书提供最新的书,快速创建健壮的,可靠,可重复使用的wxPython应用

下载
import { createasyncthunk } from '@reduxjs/toolkit';

export const fetchuserbyid = createasyncthunk(
  'user/fetchuserbyid',
  async (userid) => {
    const user = await somehttprequest(userid);
    return user;
  }
);

fetchuserbyid 是这里创建的 thunk 函数。 createasyncthunk 采用两个参数:

  • 第一个参数是用于生成的操作类型的字符串前缀(例如 user/fetchuserbyid/pending、user/fetchuserbyid/fulfilled 或 user/fetchuserbyid/rejected)。
  • 第二个参数是“有效负载创建者”函数。它应该返回一个包含所需数据或错误的 promise。

为什么使用createasyncthunk?

除了让您为 api 调用创建 thunk 函数之外,createasyncthunk 还会自动调度操作来跟踪 api 请求的状态:

  • 待处理:请求正在进行中。
  • fulmeded:请求成功。
  • 被拒绝:请求失败。

这真的很有用。例如,当状态处于挂起状态时,我们可以在 ui 中显示加载程序,并让用户知道正在发生某些事情。

在切片中使用 thunk

现在我们已经创建了 fetchuserbyid thunk,我们可以使用 userslice 中的 extrareducers 字段来处理状态状态更改:

import { createslice } from '@reduxjs/toolkit';

const initialstate = {
  user: null,
  status: 'idle', // 'idle' | 'pending' | 'succeeded' | 'failed'
  error: null,
};

export const userslice = createslice({
  name: 'user',
  initialstate,
  reducers: {
    usernameupdated: (state, action) => {
      state.user.username = action.payload;
    },
    emailupdated: (state, action) => {
      state.user.email = action.payload;
    },
    userdatacleared: (state) => {
      state.user = null;
      state.status = 'idle';
    },
  },
  extrareducers: (builder) => {
    builder
      .addcase(fetchuserbyid.pending, (state) => {
        state.status = 'pending';
      })
      .addcase(fetchuserbyid.fulfilled, (state, action) => {
        state.status = 'succeeded';
        state.user = action.payload;
      })
      .addcase(fetchuserbyid.rejected, (state, action) => {
        state.status = 'failed';
        state.error = action.error.message || 'something went wrong.';
      });
  },
});

export const { usernameupdated, emailupdated, userdatacleared } = userslice.actions;

// selector for the status to use in the application's components
export const selectstatus = (state) => state.user.status;

createasyncthunk 条件

如果我们想在调用api之前检查一些条件怎么办?例如,如果状态已经处于待处理状态,我们不想调用它两次。在这种情况下,我们可以使用 createasyncthunk 接受的第三个参数来写入条件。

export const fetchUserById = createAsyncThunk(
  "user/fetchUserById",
  async (userId) => {
    const response = await someHttpRequest(userId);
    return response;
  },
  {
    condition(_, { getState }) {
      const status = selectStatus(getState());
      if (status !== "idle") {
        return false;
      }
    },
  }
);

要了解如何将 typescript 与 thunk 函数结合使用,请阅读类型检查 redux thunk。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
TypeScript工程化开发与Vite构建优化实践
TypeScript工程化开发与Vite构建优化实践

本专题面向前端开发者,深入讲解 TypeScript 类型系统与大型项目结构设计方法,并结合 Vite 构建工具优化前端工程化流程。内容包括模块化设计、类型声明管理、代码分割、热更新原理以及构建性能调优。通过完整项目示例,帮助开发者提升代码可维护性与开发效率。

40

2026.02.13

TypeScript全栈项目架构与接口规范设计
TypeScript全栈项目架构与接口规范设计

本专题面向全栈开发者,系统讲解基于 TypeScript 构建前后端统一技术栈的工程化实践。内容涵盖项目分层设计、接口协议规范、类型共享机制、错误码体系设计、接口自动化生成与文档维护方案。通过完整项目示例,帮助开发者构建结构清晰、类型安全、易维护的现代全栈应用架构。

11

2026.02.25

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

638

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

218

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1559

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

642

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1027

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

980

2024.04.29

batoto漫画官网入口与网页版访问指南
batoto漫画官网入口与网页版访问指南

本专题系统整理batoto漫画官方网站最新可用入口,涵盖最新官网地址、网页版登录页面及防走失访问方式说明,帮助用户快速找到batoto漫画官方平台,稳定在线阅读各类漫画内容。

65

2026.02.25

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
TypeScript 教程
TypeScript 教程

共19课时 | 3.1万人学习

TypeScript——十天技能课堂
TypeScript——十天技能课堂

共21课时 | 1.2万人学习

TypeScript-45分钟入门
TypeScript-45分钟入门

共6课时 | 0.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号