翻译|重新思考Redux

作者: smartphp | 来源:发表于2017-03-15 10:28 被阅读109次

Arunoda Susiripala 参看原文,这篇文章发布有些时间了,但仍然是很好的学习资料,而且在随着学习和了解的深入,许多有意思的想法得到证实,那感觉真是很好.比如我前面诞生了一个想法,redux就是一个数据层啊!可以借助数据库的思想来学习,包括其中诞生的一些中间思想.在这篇文章有有了新的发现,在Meteor的state管理方法直接使用了minimongo cache的名字,名字里的含义不言自明了.就是这些小点慢慢使我的学习过程更加深入.当然也有一些新的想法,有兴趣的往下看看.
Dec 22, 2015


重新思考Redux

Redux是非常好的框架.这篇文章既不是Redux的扩充也不是要创建一个新的Flux库,这里是对Redux模式的重新思考.

什么是Redux?

在我们讨论新内容之前,让我们先看看Redux是什么.

Redux flow pic
  • 本质上,Redux是我们的app里存储客户端state的地方.

  • 一些actions可以改变state.

  • 我们使用纯函数来监听所有的actions并且使用当前的state作为上下文去创建新的state.这个函数叫reducer.
    (之所以叫纯函数,是因为它不会突变state,而且它也没有任何异步操作.)

  • 有很多订阅者监听着他们需要修改的state.

如果你是Redux新手,看看这些由Redux创建者发布的视频

我以前和你一样,但是我现在喜欢Redux.

为什么是Redux?

现在有足够的理由使用React构建app.我们可以使用父子数据流,Meteor的Tracker based system,Relay或者Mobservable.

这些方法对于简单app(或者中型app应用)来说还是挺好的.但是一旦app规模变大,极有可能会丧失app的控制权.

我之所以这么说是从我两次重构kandira UI的经验来的,那个过程太痛苦了.

能和Redux很高工作的构架就是Redux.

Redux是一个简单概念,它采用了一些函数式编程的概念(实际上来自Elm)和Flux的构架.

有了Redux,

  • 我们的state是可以预期的,在app中也是这样
  • app的大部分是纯函数,UI也是纯函数.所以很容易测试.
  • Redux是一个简单的库,所以没有任何魔法.
  • Redux里的模式被很多开发者使用.所有你可以依据很好的生态系统.

上面这些观点就是我认为Redux非常重要的原因.

重新思考

我们正在考虑使用客户端state和Metero后台交互来重写app.我们认为Redux的模型更合适.但是我们还有许多问题要考虑,在那些地方书写逻辑代码,怎么减少模板代码量.
我们也不怎么确信Redux的state管理怎么和其他的state管理系统整合,比如Meteor的minimongo cache(译者:单词的含义意味着可以看做简单的mongo 数据库,看到这里你有什么想法呢?).这就是为什么我们想要寻求一些改变.

现在让我们讨论一下我们建议的一些修改.

使用Redux管理UI的state

在我们的app中,我们要保留一些states,Redux就是用于UI state管理的组件.在Redux之外可能会有其他部分来管理state,例如像是REST API的缓存或者GraphQL.在Meteor中,可能是Minimongo cache.

Redux中的导航

update:
在评论和其他地方,我准备试试simple-redux-router.看起来可以在Redux中进行导航.他允许React路由器管理布局和dispatch actions到store.
我把simple-redux-router和我的sample app进行整合,整合过程还好除了即时加载过程.
现在,我们准备把React Router和Redux合并.但是我们仔细考虑一下就可以发现,routing(路由)其实是另一种用户的action,类似按钮的点击action.所以router不应该成为app的管理或者app state的管理工具.
理想Redux中的router应该应route的改变而发起actions.这就是我们需要做的工作.然后我们使用reducer来改变需要的app state.

使用模块的目录结构

推荐的是默认的布局目录结构.但是我们需要添加新的特性时,我们需要在多个目录中添加代码.
有一个模式叫做鸭子模型,建议我们按组把相关的actions creators和reducer放到一个文件中.我们准备使用这个方法.我们也准备把相互关联的组件和redux container放到一个单一目录中.

用于数据加载的一些助手函数.

我们需要数据来渲染组件,通常我们通过action creator来做这件事.但是为了把数据加载和组件渲染很好的整合在一起,我们需要写一些模板式的代码.我们可以使用一些助手方法来消除这些模板代码.

整合在一起

为了充分理解这些理念,我们必需读一些代码.这也是我们构建实例代码app的原因.
这里是repo:rethinking-redux-demo.

相关文章

网友评论

    本文标题:翻译|重新思考Redux

    本文链接:https://www.haomeiwen.com/subject/owqlnttx.html