首页 > 其他 > 详细

拆分reducer,combineReducers

时间:2019-12-22 21:14:34      阅读:116      评论:0      收藏:0      [点我收藏+]

一个网站上的功能非常多,代码量很大,但是一个文件上的代码超过300行,说明设计有问题。

reducer中,初始化数据在里面,数据操作也在里面,一个大型网站的操作数据都很多,如果都放在reducer中,必然代码非常多,就会造成不可维护性。

reducer好比一本图书查询手册,当手册内容太多,我们就可以将其分类成多个小手册。

数据和操作数据其实都是针对组件而言的,那就根据组件来划分出小手册。

 

在组件目录下,新建store目录,创建reducer.js

技术分享图片

 在组件的reducer.js中代码如下:

const defaultState = {
searchFocused: false
}
export default (state=defaultState,action) => {
if(action.type === "search_foucus"){
return {
searchFocused: true
}
}
if(action.type === "search_blur"){
return {
searchFocused: false
}
}
return state
}

第二步:在总的reducer.js中,将分支的reducer导入

import {combineReducers} from ‘redux‘
import headerReducer from ‘../common/header/store/reducer‘

export default combineReducers({
    // 给这个分支reducer命名
    header: headerReducer
})

第三步:在组件中,使用store中的数据时候,就不能再直接用state了,而是用state的header,这个header就是上面给分支reducer命的名

const mapStateToProps = (state) => {
    return {
        searchFocused: state.header.searchFocused
    }
}

 

 

 

 

拆分reducer,combineReducers

原文:https://www.cnblogs.com/shengjunyong/p/12080829.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!