内容简介:假设我们要在 React 组件中展示一组 短吻鳄(gators)的列表,数据从 GatorAPI获取, 具体的数据并不重要. 现在需要把 fetch 的数据添加到 redux 的 state 树中这个 state 的结构是
假设我们要在 React 组件中展示一组 短吻鳄(gators)的列表,数据从 GatorAPI获取, 具体的数据并不重要. 现在需要把 fetch 的数据添加到 redux 的 state 树中
这个 state 的结构是
① ② ③
Redux reducer的模式
Redux reducer 的模式其实是固定的: (prevState,action)=>nextState
根据传入的 action,对State 做出修改. 就这么简单, 修改是 Immutable的. 哪怕是一个数字加1, 也会形成新的 state, 这里很有必要使用 FB 的 Immutable.js. 如果是 prevState 和 nextState 之间有公共部分, 虽然是两个不同的对象,但是在底层Immutable.js 可以共享两个对象的共同部分.注意这并不是引用.
实例代码
const reverseMerge = flip(merge); export function fetchSuccess(state, { payload: { gators } }) { const gatorIds = map(prop("id"), gators); const gatorLookup = indexBy(prop("id"), gators); return evolve( { all: compose(uniq, concat(gatorIds)), byId: reverseMerge(gatorLookup), loading: always(false) }, state ); } 复制代码
使用的 Ramda函数
①
always: Ramda 中一切都是函数, 如果想使用 int或者字符串,也有通过函数返回 always就是为了这个出发点, val=()=>val
,
②
compose 函数: 看家函数, Ramda数据流思考的方向, 数据从右传入,经过一系列操作. 实例代码中的 用法可以翻译为 uniq(concat(gatorIds,all))
,把 prevState 的 all 属性取出,然后和远程获取的数据拼接, 使用 uniq 函数去重
③
evolve: 接收两个参数, 一组转换函数, 一个对象, 函数对对象的属性递归的进行处理
④
flip 函数: 翻转两个参数的位置, merge(a,b)
, 在 merge()中, 如果存在两个属性名相同, b对象的属性值会覆盖 a 的属性值, 在 Redux中, 操作是 merge(state,payload.data)
我们希望在出现同名属性的时候, payload 的属性会覆盖 state 的属性. 但是在 evolve
函数中, state是作为最后一个参数传递, 所以这里借助 flip
函数交换一下参数的位置.
⑤
indexBy 函数: 提取一个对象的键值作为索引
[{ id: 1, title: "one" }, { id: 2, title: "two" }] { 1: { id: 1, title: "one" }, 2: { id: 2, title: "two" } } 复制代码
⑥
map 函数 , map(elem=>console.log(elm),elements)
⑦
merge 函数
⑧
prop 函数: 返回对象的属性值,
prop("a",{a:"alligator",b:"bayou",c:"cayman"}) //=> "alligator" 复制代码
⑨
uniq函数, 接收一个列表,返回一个新列表, 重复值被去除
再看看代码
const reverseMerge = flip(merge); export function fetchSuccess(state, { payload: { gators } }) { const gatorIds = map(prop("id"), gators); const gatorLookup = indexBy(prop("id"), gators); return evolve( { all: compose(uniq, concat(gatorIds)), byId: reverseMerge(gatorLookup), loading: always(false) }, state ); } 复制代码
- 定义函数 reverseMerge,交换 merge 函数的参数
- map, gators列表, 应用 prop("id"),因此获取到 ids列表
- indexBy函数返回的列表可以通过 id属性值作为索引来访问
- evolve 函数, 接收三个函数和 state, 三个函数分别对 state 的不同属性做出修改
- state 中的all列表传递给 compose 函数和从 API获取的 gatorIds 合并, 去重, 然后返回
- state中的 byId 对象传递给 reverseMerge 函数,和 gatorLookup 合并, 重复值会被 gatorLookup 的属性值覆盖到
- Loading的值被修改为 false.
结论
实际使用时还有很多的函数可以使用, 在 Redux中有两个地方,ramda可以大有所为,一个就是这里, 还有一个地方就是container 组件包装时对state的筛选 , mapStateToProps,
以上所述就是小编给大家介绍的《摘要| Functional Redux Reducers with Ramda》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
编写高质量代码:改善Python程序的91个建议
张颖、赖勇浩 / 机械工业出版社 / 2014-6 / 59.00元
在通往“Python技术殿堂”的路上,本书将为你编写健壮、优雅、高质量的Python代码提供切实帮助!内容全部由Python编码的最佳实践组成,从基本原则、惯用法、语法、库、设计模式、内部机制、开发工具和性能优化8个方面深入探讨了编写高质量Python代码的技巧与禁忌,一共总结出91条宝贵的建议。每条建议对应Python程序员可能会遇到的一个问题。本书不仅以建议的方式从正反两方面给出了被实践证明为......一起来看看 《编写高质量代码:改善Python程序的91个建议》 这本书的介绍吧!