redux结合saga

2024-01-08 21:10
文章标签 结合 redux saga

本文主要是介绍redux结合saga,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

img

redux

1.action

State 的变化,会导致 View 的变化。但是,用户接触不到 State,只能接触到 View。所以,State 的变化必须是 View 导致的。Action 就是 View 发出的通知,表示 State 应该要发生变化了。

Action 是一个对象。其中的type属性是必须的,表示 Action 的名称。其他属性可以自由设置,社区有一个规范可以参考。

const action = {type: 'ADD_TODO',payload: 'Learn Redux'
};

2.action creator

View 要发送多少种消息,就会有多少种 Action。如果都手写,会很麻烦。可以定义一个函数来生成 Action,这个函数就叫 Action Creator。

import { GETLIST } from "./actionTypes";export const getlist = () => {return {type:GETLIST}
}

3.state

Store对象包含所有数据。如果想得到某个时点的数据,就要对 Store 生成快照。这种时点的数据集合,就叫做 State。

当前时刻的 State,可以通过store.getState()拿到

import { applyMiddleware,createStore } from "redux";
import { Map } from 'immutable'
import reducer from "./reducer";import createSagaMiddleware from 'redux-saga'
import sagas from './sagas'const sagaMiddleware = createSagaMiddleware()const store =  createStore(reducer,Map([]),applyMiddleware(sagaMiddleware)
)sagas.forEach(saga => sagaMiddleware.run(saga))export default store

4.Reducer

Store 收到 Action 以后,必须给出一个新的 State,这样 View 才会发生变化。这种 State 的计算过程就叫做 Reducer。

import { Map,List } from 'immutable'
import { LOADLIST } from './actionTypes'const defaultState = Map({doclist:List([])
})export default (state = defaultState , action) => {switch(action.type){case LOADLIST:return state.updateIn(['doclist'],()=>action.doclist)default:return state}
}

5. store.dispatch()

store.dispatch()是 View 发出 Action 的唯一方法

import React,{ useEffect } from 'react'
import Swiper2 from './Swiper2'
// import Swiper3 from './Swiper3'
import FindDoctorContainerUi from './FindDoctorContainerUi'
import { useDispatch } from 'react-redux'
import { getlist } from '../index'
import { useSelector } from 'react-redux'
import { FindDoctorMainWrapper } from './styledFindDoctorContainer'export default function FindDoctorContainer() {const dispatch = useDispatch()const docList = useSelector(state => state.getIn(['findDoc','doclist']))useEffect( () => {dispatch(getlist())},[])return (<FindDoctorContainerUi doclist={docList}></FindDoctorContainerUi>)
}

6.sagas

用于异步请求数据

sagas里面的一些参数:

​ fork:创建一个新的进程或者线程并发请求

​ call:发送api请求

​ put:发送对应的dispatch,触发对应的action

​ takeEvery:监听对应的action,每已次dispatch都会触发

​ takeLatest:监听对应的action,只会触发最后一次dispatch(触发一次动作后,又不断的触发动作,在一定的时间内。只有最后一次触发有效)

​ call:和fork一样同时发出多个action

import $http from '@/utils/http'
import { put, takeEvery, call } from 'redux-saga/effects'
import { GETLIST, LOADLIST } from './actionTypes'function* foo2(){let result = yield call($http.get, {url:'http://localhost:9000/docList'})yield put({type: LOADLIST,doclist:result.data.data})
}function* saga(){yield takeEvery(GETLIST, foo2)
}
export default saga

主要api

createStore(reducer,[preloadStore], enhancer)

Store

combineReducers(reducers)

applyMiddleware(…middlewares)

bindActionCreators

compose

redux-saga/effects

1.fork

创建一个进程或线程并发送请求

function* user() {yield takeEvery('FETCH_REQUEST', fetch_user); // 监听 FETCH_REQUEST action
}// 并发发送请求
function* fetch_user() {const [users, todos] = [yield fork(fetchResource, 'https://jsonplaceholder.typicode.com/users'),yield fork(fetchResource, 'https://jsonplaceholder.typicode.com/todos')]
}function* fetchResource(resource) {const data = yield call(axios.get, resource);// 获取 call 数据,触发成功后的 actionyield put({ type: 'FETCH_SUCESS', uu: data });
}
2.call

发送api请求

3.put

发送对应的dispatch并触发action

4.takeEvery

监听对应的 action;
每一次 dispatch 都会触发;例如:点击一个新增的按钮,2s 后触发新增动作,在2s内不断点击按钮,这时候,每一次点击,都是有效的。

5.takeLatest

监听对应的 action;
只会触发最后一次 dispatch;例如:点击一个新增的按钮,2s 后触发新增动作,在2s内不断点击按钮,这时候,只有最后一次点击是有效的。

6.all

跟 fork 一样,同时并发多个 action,没有顺序。

const rootUser = [user(),todo()
];yield all([ // 同时并发多个...rootUser, // add()
]);

这篇关于redux结合saga的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/584834

相关文章

Go 语言中Select与for结合使用break

func test(){i := 0for {select {case <-time.After(time.Second * time.Duration(2)):i++if i == 5{fmt.Println("break now")break }fmt.Println("inside the select: ")}fmt.Println("inside the for: ")}} 执行后

Jenkins--pipeline认识及与RF文件的结合应用

什么是pipeline? Pipeline,就是可运行在Jenkins上的工作流框架,将原本独立运行的单个或多个节点任务连接起来,实现单个任务难以完成的复杂流程编排与可视化。 为什么要使用pipeline? 1.流程可视化显示 2.可自定义流程任务 3.所有步骤代码化实现 如何使用pipeline 首先需要安装pipeline插件: 流水线有声明式和脚本式的流水线语法 流水线结构介绍 Node:

结合Python与GUI实现比赛预测与游戏数据分析

在现代软件开发中,用户界面设计和数据处理紧密结合,以提升用户体验和功能性。本篇博客将基于Python代码和相关数据分析进行讨论,尤其是如何通过PyQt5等图形界面库实现交互式功能。同时,我们将探讨如何通过嵌入式预测模型为用户提供赛果预测服务。 本文的主要内容包括: 基于PyQt5的图形用户界面设计。结合数据进行比赛预测。文件处理和数据分析流程。 1. PyQt5 图形用户界面设计

第二十一章 rust与动静态库的结合使用

注意 本系列文章已升级、转移至我的自建站点中,本章原文为:rust与动静态库的结合使用 目录 注意一、前言二、库生成三、库使用四、总结 一、前言 rust中多了很多类型的库,比如前面章节中我们提到基本的bin与lib这两种crate类型库。 如果你在命令行执行下列语句: rustc --help 那么你将能找到这样的内容: --crate-type [bin|li

“设计模式双剑合璧:工厂模式与策略模式在支付系统中的完美结合”

工厂模式(Factory Pattern)和策略模式(Strategy Pattern)都是常见的设计模式,但它们解决的问题和应用场景不同。下面是它们的区别: 1. 目的不同: 工厂模式(Factory Pattern): 工厂模式的主要目的是创建对象。它通过定义一个创建对象的接口,让子类决定实例化哪一个具体类,从而将对象创建的逻辑与使用的代码分离。 工厂模式可以分为简单工厂、工厂方法和抽象

Windows电脑本地安装HFS文件共享服务结合内网穿透搭建低成本NAS

文章目录 前言1.软件下载安装1.1 设置HFS访客1.2 虚拟文件系统 2. 使用cpolar建立一条内网穿透数据隧道2.1 保留隧道2.2 隧道名称2.3 创建二级子域名访问本地hfs 总结 前言 本文主要介绍如何在Windows系统电脑使用HFS并结合cpolar内网穿透工具搭建低成本NAS,并实现使用公网地址远程访问管理本地局域网电脑存储的文件。 云存储作为一个新概念

Spring回顾之五 —— 测试,JUnit与SpringTest的完美结合

没有测试的程序,是不完整的,每一个从事写程序的人员,都应该坚持做单元测试,通过单元测试可以验证程序基本功能的有效性,从而保证整个系统的质量,功在一时,利在千秋。这里我们将尝试使用Junit和SpringTest,在之前的系统里添加测试功能。 第一步:JUnit与SpringTest的引入     JUnit故名知意,是一个专门为Java语言提供单元测试的框架。平时的开发过程中,单元

Windows系统使用小皮面板搭建Kodcloud结合内网穿透体验私有云盘

文章目录 1.前言2. Kodcloud网站搭建2.1. Kodcloud下载和安装2.2 Kodcloud网页测试 3. cpolar内网穿透的安装和注册4. 本地网页发布4.1 Cpolar云端设置4.2 Cpolar本地设置 5. 公网访问测试6.结语 1.前言 本文主要为大家介绍一款国人自研的在线Web文件管理器可道云,能够支持在线管理图片、播放音乐视频、编辑和查看文件

gitlab结合docker实现CI/CD

gitlab的continue integration 和 continue delivery,因为高可用尚未实现暂时不做continue deployment 1.部署gitlab-runner 官网:https://docs.gitlab.com/runner/install/docker.html centos7下docker部署方式。 docker run -d -

结合sklearn说一下特征选择

特征选择(排序)对于数据科学家、机器学习从业者来说非常重要。好的特征选择能够提升模型的性能,更能帮助我们理解数据的特点、底层结构,这对进一步改善模型、算法都有着重要作用。 特征选择主要有两个功能: 减少特征数量、降维,使模型泛化能力更强,减少过拟合增强对特征和特征值之间的理解 拿到数据集,一个特征选择方法,往往很难同时完成这两个目的。通常情况下,我们经常不管三七二十一,选择一种自己最熟悉或者