码迷,mamicode.com
首页 > 其他好文 > 详细

[Functional Programming ADT] Combine Multiple State ADT Based Redux Reducers

时间:2019-02-07 23:45:56      阅读:157      评论:0      收藏:0      [点我收藏+]

标签:pes   provides   multi   pass   fir   width   compose   bsp   ike   

Redux provides a convenient helper for combining many reducers called combineReducer, but it focuses in on specific attributes on our state, making it incompatible with using the State ADT. We would like a way to avoid keeping all of our reducers in a single file and want the ability to still combine them in a manner that works with the State ADT.

So we will put together our own helper that we also call combineReducers, but explore how we can use the First Monoid and mreduceMap to get us all the power that the Redux helper provides, but setup for our unique needs. As a bonus we will get a sneak peak of the power of using the flipcombinator to create easy to read compositions without pesky argument juggling

 

// combineReducers :: [ Reducer ] -> Reducer
/*
export const combineReducers = reducers => action =>
  mreduceMap(First, applyTo(action), reducers);
*/
// We take reducers first and action second, but we use action first, reducers second.
// It is good case to use flip
/*
export const combineReducers = flip(action =>
  mreduceMap(First, applyTo(action))
);*/

// We can use compose to remove action param, applyTo will get action
// Then the return result will be passed into mreduceMap(First)
export const combineReducers = flip(
  compose(
    mreduceMap(First),
    applyTo
  )
);

 

 

[Functional Programming ADT] Combine Multiple State ADT Based Redux Reducers

标签:pes   provides   multi   pass   fir   width   compose   bsp   ike   

原文地址:https://www.cnblogs.com/Answer1215/p/10355624.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!