Published on

Redux快速使用

Authors

Redux

Redux is a predictable state container for JavaScript apps.

Redux是一个js应用的可预测状态容器。

Redux是根绝Flux改进的一个状态管理器,主要用于处理跨层级组件通信的问题。

Redux有三大原则

  • 整个应用的state被存储在单个的对象树中(store);
  • 状态是只读的,只能通过actions改变状态;
  • 使用纯函数进行更改状态(reducer)。

Store

Store主要有四个方法:

  • getState():获取当前的state
  • dispatch(action):发出一个action
  • subscribe(listener):添加一个监听器
  • createStore(reducer, [preloadedState], [enhancer]):创建store

在创建一个Store时可以添加中间件,如redux-thunk用于异步获取数据,redux-devtools-extension浏览器调试工具等。

redux-thunkredux-devtools-extension使用:

import { composeWithDevTools } from 'redux-devtools-extension'
import thunk from 'redux-thunk'

const middleware = [ thunk ]
if (process.env.NODE_ENV !== 'production') {
  middleware.push(createLogger())
}

const store = createStore(
  reducer,
  composeWithDevTools(applyMiddleware(...middleware))
)

在项目中添加redux-devtools-extension后再开发者调试工具中就会多出一个redux的选项。

redux-devtools-extension

Reducer

reducer是一个纯函数,大致如下:

(preState, action) => newState

禁止在reducer中修改传入参数;禁止执行有副作用的操作;禁止调用非纯函数。

React的思想是将页面抽象为一个个组件,当两个组件是相互独立时,应该为每个组件创建单独的reducer,最后使用combineReducers()将多个reducer合并。

react-redux

react-redux只有两个API。

react使用react-redux来绑定redux。将根组件包裹在<Provider>中,将store作为props传入,使项目中的任何组件都可以使用store。然后使用connect()函数真正的连接react的组件和redux的store。

export default connect(mapStateToProps)(App)

connect有四个参数:

  • mapStateToProps
  • mapDispatchToProps
  • mergeProps
  • options

1、mapStateToProps(atate, ownProps)允许我们将store中的数据作为props绑定到组件上。

第一个参数为Redux的store,第二个参数为App组件自身的参数。当store或ownProps发生变化时,mapStateToProps()函数会被调用,得出一个新的state,传递给App组件。

2、mapDispatchToProps(dispatch, ownProps)是将action作为props绑定到组件上。

Redux本身提供了bindActionCreators函数,将action包装成直接可被调用的函数,即调用该函数就会触发dispatch。

3、mergeProps(stateProps, dispatchProps, ownProps)

不管是stateProps还是dispatchProps,都需要和ownProps merge之后才会赋值给App,该函数实现了这个功能。但不传递该参数也可以,connect会使用Object.assign方法代替。

4、options

总结

redux的工作流程:

1、页面产生交互性行为,发出action;

store.dispatch(action)

2、Store调用Reducer;

var nextState = todoApp(preState, action)

3、State一旦有变化,Store就会调用监听函数。

store.subscribe(listener)

4、listener通过store.getState()获取状态,React可以触发重新渲染视图。

function listener() {
  let newState = store.getState();
  component.setState(newState)
}
redux工作流程