更简单的Redux工具 Toolkit

1 安装

npm install @reduxjs/toolkit

2 创建store目录

创建store文件夹,里面包含入口文件index.jsx,以及自定义的reduces方法main.jsx的slices文件夹,其中main1.jsx、main2.jsx表示每一个相对独立的reduces数据操作集
store
***slices
******main1.jsx
******main2.jsx
******…
***index.jsx

3 定义store结构

index.jsx(在项目入口处引入该文件)

import { configureStore } from '@reduxjs/toolkit'
import main1 from './slices/main1'
import main2 from './slices/main2'export const store = configureStore({reducer: { main1, main2 }
})export default store

main1.jsx(在页面中引入该文件)

import { createSlice, createAsyncThunk } from '@reduxjs/toolkit'const initialState = {status: 10,
}export const getRequestFn = createAsyncThunk( // 异步接口修改state'requestName',async () => {try {// 触发一个请求const { data } = await requestApi()return data} catch (err) {console.log('requestName', err)}}
)const mainSlice = createSlice({name: 'main1',initialState,reducers: {increment(state, action) {state.status = state.status + action.payload},decrement(state, action) {state.status = state.status - action.payload},changeValue(state, action) {state.status = action.payload},},extraReducers(builder) {builder.addCase(getRequestFn.fulfilled, (state, actions) => {if (!actions.payload) returnstate.status = actions.payload.status // 赋值为请求的data.status})}
})export const actions = mainSlice.actionsexport default mainSlice.reducer

4 使用

在项目入口处引入store/index.jsx,
并在需使用store的组件中引入store/slices/main.jsx
项目中的具体使用如下:

import React, { memo } from 'react'
import { useSelector, useDispatch } from 'react-redux'
// 这里引入main1的地址,main1、main2按需引入
import { actions, getRequestFn } from '**/store/slices/main1'function Home() {const { status } = useSelector(state => state.main)const dispatch = useDispatch()const handleAdd = () => {dispatch(actions.increment(1)) // status => 11}const handleAssign = () => {dispatch(actions.changeValue(100)) // status => 100}const handleRequest = () => {dispatch(getRequestFn()) // status => request data.status} return <div><div onClick={handleAdd}></div><div onClick={handleAssign}></div><div onClick={handleRequest}></div></div>
}export default Home

Redux官网

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/205416.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于Browscap对浏览器工具类优化

项目背景 原有的启动平台公共组件库comm-util的浏览器工具类BrowserUtils是基于UserAgentUtils的&#xff0c;但是该项目最后一个版本发布于 2018/01/24&#xff0c;之至今日23年底&#xff0c;已有5年没有维护更新&#xff0c;会造成最新版本的部分浏览器不能正确获取到浏览器…

使用python操作excel文档

导入xlsxwriter包 python轻量化的语言&#xff0c;用来操作文档简直易如反掌&#xff0c;首先你需要导入的是import xlsxwriter包&#xff0c;他包括了操作文档所需要的全部工具方法&#xff0c;你只需要调用就好了。 操作excel指南 首先你需要创建一个文件xlsxwriter.Workb…

http与apache

目录 1.http相关概念 2.http请求的完整过程 3.访问浏览器背后的原理过程 4.动态页面与静态页面区别 静态页面&#xff1a; 动态页面&#xff1a; 5.http协议版本 6.http请求方法 7.HTTP协议报文格式 8.http响应状态码 1xx&#xff1a;提示信息 2xx&#xff1a;成功…

代码随想录算法训练营第四十四天| 518 零钱兑换 || 377 组合总和 Ⅳ

目录 518 零钱兑换 || 377 组合总和 Ⅳ 518 零钱兑换 || 如果求组合数就是外层for循环遍历物品&#xff0c;内层for遍历背包。 class Solution { public:int change(int amount, vector<int>& coins) {vector<int> f(amount 10);//拼凑成总金额为i的总情况…

CPU密集型和IO密集型初学习

目录 1、CPU密集型 2、IO密集型 3、CPU密集型和IO密集型的区别 4、CPU密集型和IO密集型对CPU内核之间的关系 5、核心线程数计算公式 5、扩展&#xff1a;进程和线程 小结 1、CPU密集型 CPU密集型是指计算机程序或任务在执行过程中主要依赖于中央处理器&#xff08;CPU&…

IOday5作业

使用两个线程完成两个文件的拷贝&#xff0c;分支线程1完成前一半内容拷贝&#xff0c;分支线程2完成后一半内容的拷贝&#xff0c;主线程完成资源的回收 #include<myhead.h> //定义结构体 struct file {const char* srcfile;//背拷贝文件路径const char* destfile;//拷…

浏览器的缓存策略

浏览器缓存的策略主要分为两种&#xff1a;过期机制和验证机制。 过期机制&#xff1a;是指浏览器根据资源的过期时间&#xff0c;判断是否可以直接使用缓存中的副本&#xff0c;而无需向服务器发起请求。过期时间可以通过以下两种方式设置&#xff1a; Cache-Control&#xf…

C++ STL容器与常用库函数

STL是提高C编写效率的一个利器 STL容器&#xff1a; 一、#include <vector> 英文翻译&#xff1a;vector &#xff1a;向量 vector是变长数组(动态变化)&#xff0c;支持随机访问&#xff0c;不支持在任意位置O(1)插入。为了保证效率&#xff0c;元素的增删一般应该在末尾…

【设计模式-3.1】结构型——外观模式

说明&#xff1a;本文介绍设计模式中结构型设计模式中的&#xff0c;外观模式&#xff1b; 亲手下厨还是点外卖&#xff1f; 外观模式属于结构型的设计模式&#xff0c;关注类或对象的组合&#xff0c;所呈现出来的结构。以吃饭为例&#xff0c;在介绍外观模式之前&#xff0…

你们如何看待华为的鸿蒙ArkTS语言?

ArkTS是鸿蒙生态的应用开发语言。它在保持TypeScript&#xff08;简称TS&#xff09;基本语法风格的基础上&#xff0c;对TS的动态类型特性施加更严格的约束&#xff0c;引入静态类型。同时&#xff0c;提供了声明式UI、状态管理等相应的能力&#xff0c;让开发者可以以更简洁、…

要求CHATGPT高质量回答的艺术:提示工程技术的完整指南—第 26 章:让 ChatGPT 成为你自己的提示工程师

要求CHATGPT高质量回答的艺术&#xff1a;提示工程技术的完整指南—第 26 章&#xff1a;让 ChatGPT 成为你自己的提示工程师 要让 ChatGPT 成为你自己的提示工程师&#xff0c;你需要与 ChatGPT 发起对话。你可以使用下面提供的提示示例&#xff0c;内容如下&#xff1a; 步…

画好一张规范的原理图,这些点你可要注意了!

不光是代码有可读性的说法&#xff0c;原理图也有。很多时候原理图不仅仅是给自己看的&#xff0c;也会给其它人看&#xff0c;如果可读性差&#xff0c;会带来一系列沟通问题。所以&#xff0c;要养成良好习惯&#xff0c;做个规范的原理图。此外&#xff0c;一个优秀的原理图…

【云原生-K8s】镜像漏洞安全扫描工具Trivy部署及使用

基础介绍基础描述Trivy特点 部署在线下载百度网盘下载安装 使用扫描nginx镜像扫描结果解析json格式输出 总结 基础介绍 基础描述 Trivy是一个开源的容器镜像漏洞扫描器&#xff0c;可以扫描常见的操作系统和应用程序依赖项的漏洞。它可以与Docker和Kubernetes集成&#xff0c;…

temu数据如何看:多多情报通助力商家数据选品

拼多多作为中国最大的农村电商平台&#xff0c;吸引了大量的商家和消费者。对于拼多多商家来说&#xff0c;了解市场趋势、优化产品和店铺运营、了解竞争对手等方面的数据分析至关重要。为了满足商家的需求&#xff0c;拼多多推出了多多情报通&#xff08;原名&#xff1a;多多…

批量AI写作生成器有哪些?免费的批量AI写作生成器

当今信息爆炸的时代&#xff0c;文案需求量庞大&#xff0c;传统文案写作已无法满足快速迭代的需求。批量AI写作生成器应运而生&#xff0c;成为许多行业的得力助手。在众多AI写作工具中&#xff0c;147原创助手以其批量AI写作功能和在各大平台显示原创首发的特性脱颖而出。本文…

低代码:美味膳食或垃圾食品?

一、什么是低代码 低代码开发是一种软件开发方法&#xff0c;旨在通过最小化手动编码的需求&#xff0c;使应用程序的开发变得更加快速和简单。它通常涉及使用图形界面和可视化工具&#xff0c;而不是传统的编码方法&#xff0c;以减少开发过程中的繁琐步骤。 二、低代码的优…

Metasploit在红队作战中的应用

预计更新 第一章 Metasploit的使用和配置 1.1 安装和配置Metasploit 1.2 Metasploit的基础命令和选项 1.3 高级选项和配置 第二章 渗透测试的漏洞利用和攻击方法 1.1 渗透测试中常见的漏洞类型和利用方法 1.2 Metasploit的漏洞利用模块和选项 1.3 模块编写和自定义 第三章 Me…

利用TCP通信实现文件传输和通信

前言 我们上一章已经熟悉了理论知识&#xff0c;这一章来练习一下 1.实现文件的传输 1.1 客户端 dir_client.c #include <stdio.h> #include <sys/socket.h> #include <netinet/in.h> #include <arpa/inet.h> #include <sys/types.h> #include …