摘要| Functional Redux Reducers with Ramda

栏目: 服务器 · 发布时间: 5年前

内容简介:假设我们要在 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
   );
 }
复制代码
  1. 定义函数 reverseMerge,交换 merge 函数的参数
  2. map, gators列表, 应用 prop("id"),因此获取到 ids列表
  3. indexBy函数返回的列表可以通过 id属性值作为索引来访问
  4. evolve 函数, 接收三个函数和 state, 三个函数分别对 state 的不同属性做出修改
  5. state 中的all列表传递给 compose 函数和从 API获取的 gatorIds 合并, 去重, 然后返回
  6. state中的 byId 对象传递给 reverseMerge 函数,和 gatorLookup 合并, 重复值会被 gatorLookup 的属性值覆盖到
  7. Loading的值被修改为 false.

结论

实际使用时还有很多的函数可以使用, 在 Redux中有两个地方,ramda可以大有所为,一个就是这里, 还有一个地方就是container 组件包装时对state的筛选 , mapStateToProps,


以上所述就是小编给大家介绍的《摘要| Functional Redux Reducers with Ramda》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

ACM国际大学生程序设计竞赛题解

ACM国际大学生程序设计竞赛题解

赵端阳//袁鹤 / 电子工业 / 2010-6 / 38.00元

《ACM国际大学生程序设计竞赛题解(1)》可以作为高等院校有关专业的本科和大专学生参加国际大学生程序设计竞赛的辅导教材,或者作为高等院校数据结构、C/C++程序设计或算法设计与分析等相关课程的教学参考书。随着各大专院校参加ACM/ICPC热情的高涨,迫切需要有关介绍ACM国际大学生程序设计竞赛题解的书籍。《ACM国际大学生程序设计竞赛题解(1)》根据浙江大学在线题库的前80题,进行了解答(个别特别......一起来看看 《ACM国际大学生程序设计竞赛题解》 这本书的介绍吧!

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换