freeCodeCamp/curriculum/challenges/italian/03-front-end-development-li.../redux/write-a-counter-with-redux.md

3.6 KiB

id title challengeType forumTopicId dashedName
5a24c314108439a4d4036157 Scrivere un contatore con Redux 6 301453 write-a-counter-with-redux

--description--

Ora hai imparato tutti i principi fondamentali di Redux! Hai visto come creare azioni e creatori di azioni, creare uno store di Redux, inviare le tue azioni allo store e progettare gli aggiornamenti di stato con i reducer puri. Hai visto anche come gestire uno stato complesso con la composizione di reducer e la gestione di azioni asincrone. Questi esempi sono semplicistici, ma questi concetti sono i principi fondamentali di Redux. Se li capisci bene, sei pronto a iniziare a costruire la tua app con Redux. Le prossime sfide copriranno alcuni dettagli relativi all'immutabilità dello state, ma prima, ecco un ripasso di tutto quello che hai imparato finora.

--instructions--

In questa lezione, realizzerai da zero un semplice contatore con Redux. Le basi sono fornite nell'editor di codice, ma dovrai riempire i dettagli! Utilizza i nomi forniti e definisci i creatori di azione incAction e decAction, il reducer counterReducer(), i tipi di azione INCREMENT e DECREMENT, e infine lo store di Redux. Una volta terminato, dovresti essere in grado di inviare le azioni INCREMENT o DECREMENT per aumentare o diminuire lo stato mantenuto nello store. Buona fortuna per la costruzione della tua prima app Redux!

--hints--

Il creatore di azioni incAction dovrebbe restituire un oggetto azione con type uguale al valore di INCREMENT

assert(incAction().type === INCREMENT);

Il creatore di azione decAction dovrebbe restituire un oggetto azione con type uguale al valore di DECREMENT

assert(decAction().type === DECREMENT);

Lo store Redux dovrebbe essere inizializzato con uno state di 0.

assert(_store.getState() === 0);

Effettuare il dispatch di incAction nello store Redux dovrebbe aumentare lo state di 1.

assert(
  (function () {
    const initialState = _store.getState();
    _store.dispatch(incAction());
    const incState = _store.getState();
    return initialState + 1 === incState;
  })()
);

Effettuare il dispatch di decAction nello store Redux dovrebbe decrementare lo state di 1.

assert(
  (function () {
    const initialState = _store.getState();
    _store.dispatch(decAction());
    const decState = _store.getState();
    return initialState - 1 === decState;
  })()
);

counterReducer dovrebbe essere una funzione

assert(typeof counterReducer === 'function');

--seed--

--seed-contents--

const INCREMENT = null; // Define a constant for increment action types
const DECREMENT = null; // Define a constant for decrement action types

const counterReducer = null; // Define the counter reducer which will increment or decrement the state based on the action it receives

const incAction = null; // Define an action creator for incrementing

const decAction = null; // Define an action creator for decrementing

const store = null; // Define the Redux store here, passing in your reducers

--after-user-code--

const _store = Redux.createStore(counterReducer)

--solutions--

const INCREMENT = 'INCREMENT';
const DECREMENT = 'DECREMENT';

const counterReducer = (state = 0, action) => {
  switch(action.type) {
    case INCREMENT:
      return state + 1;
    case DECREMENT:
      return state - 1;
    default:
      return state;
  }
};

const incAction = () => {
  return {
    type: INCREMENT
  }
};

const decAction = () => {
  return {
    type: DECREMENT
  }
};

const store = Redux.createStore(counterReducer);