redux-saga中间件

瞿博易
2023-12-01

懒得废话了,既然您找到这里,肯定知道要用 redux-saga 做什么事情了。
1、新建saga的文件夹, 例如 saga/home_saga.js

import {
    all,
    put,
    takeEvery
} from 'redux-saga/effects';

function* getHomeListFn(){
    yield put({type: 'xxxxx'})
    // 进行到这里是已经对页面触发的 dispatch 为 getHomeList_type做了拦截到了这里
    // 然后这里进行接口请求 对数据做处理后 再出发一次action
}

function* getHomeList() {
    yield takeEvery('getHomeList_type', getHomeListFn()) // 监听type类型以及触发事件
}

function* homeSaga_model() {
    yield all([getHomeList()]) // 数组类型, 可以同时监听多个saga事件
}

export default homeSaga_model;

2、如何将 saga 文件进行注入

以 create-react-app 为例,index.js 文件之前使用了redux,大概是这种

import { createStore } from 'redux';
import { Provider } from 'react-redux';
import allStore from 'xxxx/xxx/index'; // reducer模块化,统一导出
...
let store = createStore(allStore);
...
<Provider store={store}> // 数据可以注入到页面中, 页面中使用connect就可以连接了
    xxxx
</Provider>

之后我们以这个为基础 再注入 saga

import { createStore, applyMiddleware } from 'redux';
import { Provider } from 'react-redux';
import createSagaMiddleware from 'redux-saga';
import homeSagas from 'xxxx/xxxx/homeSaga.js';
import allStore from 'xxxx/xxx/index'; // reducer模块化,统一导出

...
let sagaMiddle = createSagaMiddleware();
let store = createStore(allStore, applyMiddleware(sagaMiddle));
// 通过 applyMiddleware 将saga注入到redux中,就可以进行监听,进行一个劫持
sagaMiddle.run(homeSagas)// 上一段已经注入saga了,这句话是运行写的单个saga文件,
...
<Provider store={store}> // 数据可以注入到页面中, 页面中使用connect就可以连接了
    xxxx
</Provider>

一会我把代码看看上传到git, 地址链接

 类似资料: