Redux介绍
学过 Vue框架 的同学们应该对 Vuex有所了解
其实 Redux 和 Vuex 的作用是相同的,但是 Redux 要比 Vuex 学习成本要高

注意:常考点
- Redux基本概念
- 单向数据流
- react-redux
- 异步action
- 中间件
代码演示:
import { createStore } from 'redux';
/**
* 这是一个 reducer,形式为 (state, action) => state 的纯函数。
* 描述了 action 如何把 state 转变成下一个 state。
*
* state 的形式取决于你,可以是基本类型、数组、对象、
* 甚至是 Immutable.js 生成的数据结构。惟一的要点是
* 当 state 变化时需要返回全新的对象,而不是修改传入的参数。
*
* 下面例子使用 `switch` 语句和字符串来做判断,但你可以写帮助类(helper)
* 根据不同的约定(如方法映射)来判断,只要适用你的项目即可。
*/
function counter(state = 0, action) {
switch (action.type) {
case 'INCREMENT':
return state + 1;
case 'DECREMENT':
return state - 1;
default:
return state;
}
}
// 创建 Redux store 来存放应用的状态。
// API 是 { subscribe, dispatch, getState }。
let store = createStore(counter);
// 可以手动订阅更新,也可以事件绑定到视图层。
store.subscribe(() =>
console.log(store.getState())
);
// 改变内部 state 惟一方法是 dispatch 一个 action。
// action 可以被序列化,用日记记录和储存下来,后期还可以以回放的方式执行
store.dispatch({ type: 'INCREMENT' });
// 1
store.dispatch({ type: 'INCREMENT' });
// 2
store.dispatch({ type: 'DECREMENT' });
// 1
单向数据流
- dispatch(action)
- reducer->newState
- subscribe 触发通知
react-redux
- connect
- mapStateToProps mapDispatchToProps
异步 action
- redux-thunk
- redux-promise
- redux-saga


前提:

redux中间件


8589

被折叠的 条评论
为什么被折叠?



