内容简介:一直对于从需求出发,看看使用对
一直对于 redux
处于一知半解的状态,有幸看到Wang Namelos老师在知乎上一段回答,认真读了三遍,犹如醍醐灌顶,推荐给大家,内容如下:
Redux
从需求出发,看看使用 React
需要什么:
-
React
有props
和state
:props
意味着父级分发下来的属性,state
意味着组件内部可以自行管理的状态,并且整个React
没有数据向上回溯的能力,也就是说数据只能单向向下分发,或者自行内部消化。理解这个是理解React
和Redux
的前提。 -
一般构建的
React
组件内部可能是一个完整的应用,它自己工作良好,你可以通过属性作为API控制它。但是更多的时候发现React
根本无法让两个组件互相交流,使用对方的数据。然后这时候不通过DOM
沟通(也就是React
体制内)解决的唯一办法就是提升state
,将state
放到共有的父组件中来管理,再作为props
分发回子组件。 -
子组件改变父组件
state
的办法只能是通过onClick
触发父组件声明好的回调,也就是父组件提前声明好函数或方法作为契约描述自己的state
将如何变化,再将它同样作为属性交给子组件使用。这样就出现了一个模式:数据总是单向从顶层向下分发的,但是只有子组件回调在概念上可以回到state
顶层影响数据。这样state
一定程度上是响应式的。 -
为了面临所有可能的扩展问题,最容易想到的办法就是把所有
state
集中放到所有组件顶层,然后分发给所有组件。 -
为了有更好的
state
管理,就需要一个库来作为更专业的顶层state
分发给所有React
应用,这就是Redux
。让我们回来看看重现上面结构的需求:
-
需要回调通知
state
(等同于回调参数) ->action
-
需要根据回调处理 (等同于父级方法) ->
reducer
-
需要
state
(等同于总状态) ->store
对 Redux
来说只有这三个要素:
-
action
是纯声明式的数据结构,只提供事件的所有要素,不提供逻辑。 -
reducer
是一个匹配函数,action
的发送是全局的:所有的reducer
都可以捕捉到并匹配与自己相关与否,相关就拿走action
中的要素进行逻辑处理,修改store
中的状态,不相关就不对state
做处理原样返回。 -
store
负责存储状态并可以被react api
回调,发布action
.
当然一般不会直接把两个库拿来用,还有一个 binding
叫 react-redux
, 提供一个 Provider
和 connect
。很多人其实看懂了 redux
卡在这里。
-
Provider
是一个普通组件,可以作为顶层app
的分发点,它只需要store
属性就可以了。它会将state
分发给所有被connect
的组件,不管它在哪里,被嵌套多少层。 -
connect
是真正的重点,它是一个科里化函数,意思是先接受两个参数(数据绑定mapStateToProps
和事件绑定mapDispatchToProps
),再接受一个参数(将要绑定的组件本身)。
mapStateToProps
:构建好 Redux
系统的时候,它会被自动初始化,但是你的 React
组件并不知道它的存在,因此你需要分拣出你需要的 Redux
状态,所以你需要绑定一个函数,它的参数是 state
,简单返回你关心的几个值。
mapDispatchToProps
:声明好的 action
作为回调,也可以被注入到组件里,就是通过这个函数,它的参数是 dispatch
,通过 redux
的辅助方法 bindActionCreator
绑定所有 action
以及参数的 dispatch
,就可以作为属性在组件里面作为函数简单使用了,不需要手动 dispatch
。这个 mapDispatchToProps
是可选的,如果不传这个参数redux会简单把 dispatch
作为属性注入给组件,可以手动当做 store.dispatch
使用。这也是为什么要科里化的原因。
做好以上流程 Redux
和 React
就可以工作了。简单地说就是:
React
以上所述就是小编给大家介绍的《通俗易懂地理解Redux》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 通俗易懂地理解Redux
- 通俗易懂理解ES6 - 变量的解构赋值
- 通俗易懂理解ES6 - 变量声明命令及其块级作用域
- 通俗易懂理解ES6 - ES6的变量类型及Iterator
- IM开发基础知识补课(五):通俗易懂,正确理解并用好MQ消息队列
- SVM 原理详解,通俗易懂
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。