Redux中combineReducers实现原理-创新互联
使用一个reducer
const initialState =
{
id : 2,
name : 'myName',
}
import { createStore } from 'redux';
const reducer = function(state=initialState, action) {
//...
return state;
}
const store = createStore(reducer);
这种情况下,这个reducer函数会对所有的action进行判断和处理,传入的state参数是整个store中的状态的全集。可能是这样:
目前成都创新互联已为上千多家的企业提供了网站建设、域名、虚拟空间、网站托管维护、企业网站设计、富蕴网站维护等服务,公司将坚持客户导向、应用为本的策略,正道将秉承"和谐、参与、激情"的文化,与客户和合作伙伴齐心协力一起成长,共同发展。{
id : 2,
name : 'myName',
}
使用combineReducers 复合多个reducer
const user = (state = [], action) => {
switch (action.type) {
case 'RENAME':
//...
default:
return state;
}
}
const product = (state = [], action) => {
switch (action.type) {
case 'SOLD':
//...
default:
return state;
}
}
const reducers = combineReducers({
user,
product,
});
const store = createStore(reducers);
这种情况下,每个reducer会对相关的action进行处理,返回与之相关的状态。(而实际实现是,combineReducers将所有reducer合并成立一个大的reducer)。
整个store的状态全集会是如下样子:
{
user: {
id: 0,
name: 'myNmae',
},
product: {
id: 0,
is_sold: 0,
}
}
可以看出这是一个树形结构,每个reducer所处理的数据在自己的分支结构中。因此,每个reducer可以独立的编写,无需关注其他reducer的数据(state)处理方式。同样,dispatch的时候只要发送与之相关的内容即可。
譬如,写一个“我”的reducer:
const initialState =
{
name : null,
displayName : null,
};
const me = (state = initialState, action) =>
{
switch (action.type)
{
case 'SET_ME':
{
const { name, displayName } = action.payload;
return { name, displayName };
}
default:
return state;
}
};
//想要设置“我”的属性,只要:
store.dispatch({
type : 'SET_ME',
payload : { "jacky", "小王"}
});
但是,事实上每个dispatch发出之后,所有reducer都会被调用一遍(只是大部分事不关己,直接返回自己的state),最终会返回一个完整的状态树,就像上面看到的样子。
编码建议
对于复杂的应用,可以编写多个reducer,每个reducer专注处理一类state。
可以将多个reducer的实现放到一个文件里实现,也可以每个reducer使用一个单独的文件(便于分工)。
另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
文章名称:Redux中combineReducers实现原理-创新互联
文章分享:http://scyanting.com/article/csoije.html