Redux - Exemple de réaction

Voici un petit exemple d'application react et Redux. Vous pouvez également essayer de développer de petites applications. Un exemple de code pour le compteur d'augmentation ou de diminution est donné ci-dessous -

Il s'agit du fichier racine qui est responsable de la création du magasin et du rendu de notre composant d'application react.

/src/index.js

import React from 'react'
import { render } from 'react-dom'
import { Provider } from 'react-redux'
import { createStore } from 'redux';
import reducer from '../src/reducer/index'
import App from '../src/App'
import './index.css';

const store = createStore(
   reducer,
   window.__REDUX_DEVTOOLS_EXTENSION__ && 
   window.__REDUX_DEVTOOLS_EXTENSION__()
)
render(
   <Provider store = {store}>
      <App />
   </Provider>, document.getElementById('root')
)

C'est notre composant racine de react. Il est responsable du rendu du composant de conteneur de compteur en tant qu'enfant.

/src/app.js

import React, { Component } from 'react';
import './App.css';
import Counter from '../src/container/appContainer';

class App extends Component {
   render() {
      return (
         <div className = "App">
            <header className = "App-header">
               <Counter/>
            </header>
         </div>
      );
   }
}
export default App;

Ce qui suit est le composant conteneur qui est responsable de fournir l'état de Redux pour réagir composant -

/container/counterContainer.js

import { connect } from 'react-redux'
import Counter from '../component/counter'
import { increment, decrement, reset } from '../actions';

const mapStateToProps = (state) => {
   return {
      counter: state
   };
};
const mapDispatchToProps = (dispatch) => {
   return {
      increment: () => dispatch(increment()),
      decrement: () => dispatch(decrement()),
      reset: () => dispatch(reset())
   };
};
export default connect(mapStateToProps, mapDispatchToProps)(Counter);

Ci-dessous, le composant de réaction responsable de la partie vue -

/component/counter.js
import React, { Component } from 'react';
class Counter extends Component {
   render() {
      const {counter,increment,decrement,reset} = this.props;
      return (
         <div className = "App">
            <div>{counter}</div>
            <div>
               <button onClick = {increment}>INCREMENT BY 1</button>
            </div>
            <div>
               <button onClick = {decrement}>DECREMENT BY 1</button>
            </div>
            <button onClick = {reset}>RESET</button>
         </div>
      );
   }
}
export default Counter;

Voici les créateurs d'actions responsables de la création d'une action -

/actions/index.js
export function increment() {
   return {
      type: 'INCREMENT'
   }
}
export function decrement() {
   return {
      type: 'DECREMENT'
   }
}
export function reset() {
   return { type: 'RESET' }
}

Ci-dessous, nous avons montré la ligne de code du fichier réducteur qui est responsable de la mise à jour de l'état dans Redux.

reducer/index.js
const reducer = (state = 0, action) => {
   switch (action.type) {
      case 'INCREMENT': return state + 1
      case 'DECREMENT': return state - 1
      case 'RESET' : return 0 default: return state
   }
}
export default reducer;

Au départ, l'application se présente comme suit -

Lorsque je clique sur incrémenter deux fois, l'écran de sortie sera comme indiqué ci-dessous -

Lorsque nous le décrémentons une fois, il affiche l'écran suivant -

Et la réinitialisation ramènera l'application à son état initial qui est la valeur du compteur 0. Ceci est illustré ci-dessous -

Comprenons ce qui se passe avec les outils de développement Redux lorsque la première action d'incrémentation a lieu -

L'état de l'application sera déplacé vers le moment où seule l'action d'incrémentation est envoyée et le reste des actions est ignoré.

Nous vous encourageons à développer une petite application Todo en tant que mission par vous-même et à mieux comprendre l'outil Redux.