V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
• 请不要在回答技术问题时复制粘贴 AI 生成的内容
yazoox
V2EX  ›  程序员

reactjs - 单独使用 reducer 可以正常工作,但使用 combineReducers 后,就不工作了?

  •  
  •   yazoox · 2020-04-29 17:30:50 +08:00 · 1133 次点击
    这是一个创建于 1710 天前的主题,其中的信息可能已经有所发展或是发生改变。
    import rootReducer from "./reducers";
    import itemReducer from "./reducers/itemReducer";
    import rootSaga from "./Sagas";
    
    const sagaMiddleware = createSagaMiddleware();
    const enhancer = composeWithDevTools(applyMiddleware(sagaMiddleware));
    
    const store = createStore(rootReducer, enhancer); // 不能工作
    // const store = createStore(itemReducer, enhancer); //可以正常工作
    
    sagaMiddleware.run(rootSaga);
    

    reducers/index.js

    import { combineReducers } from "redux"
    import itemReducer from "./itemReducer"
    
    const rootReducer = combineReducers({
        itemReducer
     })
    
     export default rootReducer;
    

    如上所示, 如果我 createStore 传 rootReducer,我的项目就不工作。 但是,如果我 createStore 传 itemReducer,就可以正常工作。

    是我的 combineReducers 调用不正确。还是说,当使用 combineReducers 后,我应该在其它地方做相应的修改么? 我 debug 了一下,console.log(store.getState()),好像和只调用一个 itemReducer 时不一样, 不是很清楚,比如 mapStateToProps,等地方是不是也要修改(或者如何修改)?我有好多 map... 那不都得修改?

    谢谢!

    Image-20200429-3.jpg Image-20200429-4.jpg

    6 条回复    2020-04-29 18:34:05 +08:00
    noobma
        1
    noobma  
       2020-04-29 17:42:05 +08:00
    不懂 react-redux,不过你想要打平的话,用 {...itemReducer} 这种写法应该就好了,但是你有好多,不知道会不会冲突😂😂
    sleepwalker
        2
    sleepwalker  
       2020-04-29 17:55:53 +08:00
    "项目就不工作"是什么个情况?
    l1nyanm1ng
        3
    l1nyanm1ng  
       2020-04-29 18:16:31 +08:00
    肯定要修改,现在你使用了 combineReducers,原本在 mapStateToProps 的地方想要取出 itemReducer 的状态,都需要加一个命名空间 itemReducer,
    比如原来你 itemReducer 的结构为 { "color": "string", nested: { count: 2, array: [] } },未使用 combineReducers 时,mapStateToProps 只需要写成 rootState => ({ color: rootState.color, count: rootState.nested.count }),
    现在你用 combineReducers 就是将 itemReducer 加了一个命名空间了,现在的 mapStateToProps 需要这么写 rootState => ({ color: rootState.itemReducer.color, count: rootState.itemReducer.nested.count }),

    顺便补一句,现在 hooks 这么好用,你怎么还在用 react-redux 的 connect 高阶函数,直接用 react-redux 的 useSelector 太香了,还有 saga 用得感觉算小众了,直接 redux-thunk 比较简单
    yazoox
        4
    yazoox  
    OP
       2020-04-29 18:17:13 +08:00
    @sleepwalker
    @noobma

    搞定了!就是调用 mapStateToProps(state) => {index = state.index} 的参数 state 时,也需要对应修改
    以前是
    state.index
    现在是
    state.itemReducer.index

    可以给 itemReducer 命个别名,读起来更容易一些。

    这可真是绕啊......
    yazoox
        5
    yazoox  
    OP
       2020-04-29 18:22:41 +08:00
    @l1nyanm1ng 谢谢解答

    我们项目 /产品是三年前的,已成型了,很多用法都是以前的。使用 redux 管理数据存储和共享 ,用 saga 解决异步调用。(我要是有能力 refactor architecture 的话...... )

    我是最近才开始学习的,前端变化太快了,这才三年啊......

    另,redux-saga 好像就是因为 redux-thunk 不太好用,才设计出来的吧?
    l1nyanm1ng
        6
    l1nyanm1ng  
       2020-04-29 18:34:05 +08:00
    @yazoox 确实是,redux-saga 是为了解决以前 redux-thunk 内回调函数写法才萌生的,但是 generator 的写法已经有后来的 async/await 写法完美替代了,generator 写法感觉是一种中间过渡态的解决方案,我感觉 generator 理解起来还是挺难的

    anyway,一切维稳最重要!不加工资不出问题就不用动以前的代码了
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2413 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 26ms · UTC 15:54 · PVG 23:54 · LAX 07:54 · JFK 10:54
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.