持续创作,加速成长!这是我参与「掘金日新计划 · 10 月更文挑战」的第4天,点击查看活动详情
🎈大家好,我是
橙橙子,新人初来乍到,请多多关照~📝小小的前端一枚,分享一些日常的学习和项目实战总结~
😜如果本文对你有帮助的话,帮忙点点赞呀!ღ( ´・ᴗ・` )比心~
React中的Data FLOW,单向数据流,只是一种架构方式。主要有2种实现:1.Flux 2.Redux
Flux
Flux 应用主要包含四个部分:
-
dispatcher
处理动作分发,维护 Store 之间的依赖关系 -
stores
数据和逻辑部分 -
views
React 组件,这一层可以看作 controller-views,作为视图同时响应用户交互 -
actions
提供给 dispatcher 传递数据给 store
Flux的单向数据流:
- 首先要有 action,通过定义一些 action creator 方法根据需要创建 Action 提供给 dispatcher
- View 层通过用户交互(比如 onClick)会触发 Action
- Dispatcher 会分发触发的 Action 给所有注册的 Store 的回调函数
- Store 回调函数根据接收的 Action 更新自身数据之后会触发一个 change 事件通知 View 数据更改了
- View 会监听这个 change 事件,拿到对应的新数据并调用
setState更新组件 UI
Action -> Dispatcher -> Store -> View
Redux
基本原则
- 整个应用只有唯一一个可信数据源,也就是只有一个 Store
- State 只能通过触发 Action 来更改
- State 的更改必须写成纯函数,也就是每次更改总是返回一个新的 State,在 Redux 里这种函数称为 Reducer
Actions
是一个单纯的包含 { type, payload } 的对象,type 是一个常量用来标示动作类型,payload 是这个动作携带的数据。Action 需要通过 store.dispatch() 方法来发送。
Reducers
Reducer 用来处理 Action 触发的对状态树的更改。
所以一个 reducer 函数会接受 oldState 和 action 两个参数,返回一个新的 state:(oldState, action) => newState。
Store
Store 的作用就是连接Action 和 Reducer,Store 的作用有:
- Hold 住整个应用的 State 状态树
- 提供一个
getState()方法获取 State - 提供一个
dispatch()方法发送 action 更改 State - 提供一个
subscribe()方法注册回调函数监听 State 的更改
Data Flow
以上提到的 store.dispatch(action) -> reducer(state, action) -> store.getState() 其实就构成了一个“单向数据流”,我们再来总结一下。
1. 调用 store.dispatch(action)
Action 是一个包含 { type, payload } 的对象,它描述了“发生了什么”,比如:
{ type: 'LIKE_ARTICLE', articleID: 42 }
{ type: 'FETCH_USER_SUCCESS', response: { id: 3, name: 'Mary' } }
{ type: 'ADD_TODO', text: 'Read the Redux docs.' }
你可以在任何地方调用 store.dispatch(action),比如组件内部,Ajax 回调函数里面等等。
2. Action 会触发给 Store 指定的 root reducer
root reducer 会返回一个完整的状态树,State 对象上的各个字段值可以由各自的 reducer 函数处理并返回新的值。
- reducer 函数接受
(state, action)两个参数 - reducer 函数判断
action.type然后处理对应的action.payload数据来更新并返回一个新的 state
3. Store 会保存 root reducer 返回的状态树
新的 State 会替代旧的 State,然后所有 store.subscribe(listener) 注册的回调函数会被调用,在回调函数里面可以通过 store.getState() 拿到新的 State。
这就是 Redux 的运作流程,接下来看如何在 React 里面使用 Redux。