Redux asynchronous

As scenarios get more complex, it becomes less desirable and unmaintainable to dispatch after the asynchronous results are in. Redux doesn’t intend to solve this problem on its own, but by providing Middleware, it can build on this layer.

Redux-thunk, redux-Promise, and redux-saga are well-known examples of Redux asynchronous middleware.

For details on how these middlware works, see my recent proofread article Redux four Asynchronous Brothers, or Redux 4 Ways if you doubt the translation.

Standardized actions

Redux itself does not specify what format an action should be, but as a matter of practice, we know that actions typically contain type and payload.

How to better write standardized actions? You can look at redux-Actions.

If you don’t want to take a closer look at redux-Actions, here’s a quick look:

Standardized actions in team development

If action design is not regulated in multiplayer development, there may be many different forms of action, such as:

type:... |text:... { type: ... , data: ... , } { actionType: ... , data: ... , } { type: ... , payload: ... ,}Copy the code

Then how to design an action that can be accepted by everyone? In the course of action evolution, the design of Flux Standard Action is widely respected.

It states that an action must be an object and contain at least one property with a key of type representing the action type. You can also have a payload to tell you what data the action is carrying, an error attribute to tell you whether the action is “wrong,” and a meta attribute to tell you some other information, but that’s optional.

Redux-actions encapsulates a createAction function, which allows us to write a more minimalist Action Creator that meets Flux Standard action standards.

We wrote Action Creator like this:

import * as types from '.. /constant'; export function fetchingLogin() { return { type: types.FETCHING_LOGIN_SUCCESS, } } export function fetchingLoginSuccess(payload) { return { type: types.FETCHING_LOGIN_SUCCESS, payload, } } export function fetchingLoginFailure(payload) { return { type: types.FETCHING_LOGIN_FAILURE, payload, error: true, } }Copy the code

With redux-Actions, we just need to do this:

import { createAction } from "redux-actions"; import * as types from '.. /constant'; export const fetchingLogin = createAction(types.FETCHING_LOGIN); export const fetchingLoginSuccess = createAction(types.FETCHING_LOGIN_SUCCESS, data => data); export const fetchingLoginFailure = createAction(types.FETCHING_LOGIN_FAILURE, data => data);Copy the code

This will create a very standardized action.

Likewise, we can still do the following in Reducer:

import * as actions from '../action';

const initState = {
  status: true,
}

export default function isLoginReducer(state = initState, action) {
  switch(action.type) {
    case actions.CHANGE_IS_LOGIN: {
      return {
        ...state,
        status: action.payload,
      }
    }
    default: {
      return state;
    }
  }
}Copy the code

Of course, redux-Actions provides a more concise API for handleActions to write a more concise renducer:

import { handleActions } from 'redux-actions'; import * as actions from '.. /action'; const initState = { status: true, } const isLoginReducer = handleActions({ [actions.changeIsLogin]: (state, action) => ({ ... state, status: action.payload }), }, initState); export default isLoginReducer;Copy the code

This way, teach your partner to use Redux-Actions and write consistent actions.

No more yelling WTF at messy actions!

I hear it’s best practice

The industry’s practice style for Redux has remained largely consistent, which means that the redux 4 Ways style created above solves most of the problems.

It is important to note that it is best to keep the React component pure and keep no coupling with Redux. Dispatches associated with Redux can be placed in the Container component by passing the mapDispatchToProps to the Container in Connect and calling the corresponding function:

import { changeIsLogin } from '.. /.. /action'; const mapDispatchToProps = (dispatch, ownProps) => { return { changeIsLogin: (status) => { dispatch(changeIsLogin(status)); } } } this.props.changeIsLogin(! this.props.isLogin.status)Copy the code

Did this article help you? Welcome to join the front End learning Group wechat group: