【发布时间】:2017-09-14 12:17:17
【问题描述】:
以前有人问过类似的问题,但答案对我没有任何帮助。
How to get something from the state / store inside a redux-saga function?
我认为我有不同的设置,因为我似乎无法从我的传奇中访问状态。
我试过了:
const getList = store => store;
const getList = state=> state;
这两个都返回undefined。
我的店铺是这样的……
export default function createStoreWithMiddleware() {
const sagaMiddleware = createSagaMiddleware();
const loggerMiddleware = createLogger();
const middleware = [sagaMiddleware, loggerMiddleware];
const persistedState = localStorage.getItem('reduxState') ? JSON.parse(localStorage.getItem('reduxState')) : {};
const store = createStore(reducer, persistedState, compose(
applyMiddleware(...middleware)
));
store.subscribe(() => {
localStorage.setItem('reduxState', JSON.stringify(store.getState()));
});
sagaMiddleware.run(rootSaga);
return store;
}
我想在这个传奇中访问我的列表:
function* selectTender(action) {
try {
const response = yield Api.getTenderById(action.payload);
yield put({type: 'SELECT_TENDER_SUCCEEDED', currentTender: response});
const list = yield select(getList);
yield put({type: 'FETCH_CHAPTERS', chaptersList: list, tenderId: response.id});
} catch (err) {
yield put({type: 'SELECT_TENDER_FAILED', message: err.message});
}
}
export function* watchSelectTender(){
yield takeEvery('SELECT_TENDER', selectTender);
}
但就像我说的,state 和 store 都是未定义的。
那么,我如何在 saga 中访问我的商店(或状态)?
【问题讨论】:
标签: reactjs react-redux redux-saga