freeCodeCamp/curriculum/challenges/italian/03-front-end-development-li.../redux/handle-an-action-in-the-sto...

3.2 KiB

id title challengeType forumTopicId dashedName
5a24c314108439a4d4036150 Gestire un'azione nello store 6 301444 handle-an-action-in-the-store

--description--

Dopo che un'azione è stata creata e spedita, lo store di Redux deve sapere come rispondere a quell'azione. Questo è il lavoro di una funzione reducer (riduttore). I reducer in Redux sono responsabili delle modifiche allo stato che si verificano in risposta alle azioni. Un reducer prende state e action come argomenti, e restituisce sempre un nuovo state. È importante capire che questo è l'unico ruolo del reducer. Questo non ha effetti collaterali - non chiama mai un endpoint API e non ha mai sorprese nascoste. Il reducer è semplicemente una funzione pura che prende uno stato e un'azione, e restituisce un nuovo stato.

Un altro principio chiave in Redux è che lo state è di sola lettura. In altre parole, la funzione reducer deve sempre restituire una nuova copia dello state e non modificare mai direttamente lo state. Redux non forza l'immutabilità dello stato, tuttavia sei responsabile di applicarlo nel codice delle tue funzioni reducer. Nelle prossime sfide farai pratica con questo.

--instructions--

L'editor di codice contiene l'esempio precedente e l'inizio di una funzione reducer pronti per te. Compila il corpo della funzione reducer in modo che se riceve un'azione di tipo 'LOGIN' restituisca un oggetto stato con login impostato a true. Altrimenti, restituisce lo state attuale. Nota che lo state corrente e l'action inviata sono passati al reducer, in modo da poter accedere direttamente al tipo di azione con action.type.

--hints--

Chiamare la funzione loginAction dovrebbe restituire un oggetto con proprietà type impostata sulla stringa LOGIN.

assert(loginAction().type === 'LOGIN');

Lo store dovrebbe essere inizializzato con un oggetto con proprietà login impostata su false.

assert(store.getState().login === false);

Inviare loginAction dovrebbe aggiornare la proprietà login nello stato dello store a true.

assert(
  (function () {
    const initialState = store.getState();
    store.dispatch(loginAction());
    const afterState = store.getState();
    return initialState.login === false && afterState.login === true;
  })()
);

Se l'azione non è di tipo LOGIN, lo store dovrebbe restituire lo stato corrente.

assert(
  (function () {
    store.dispatch({ type: '__TEST__ACTION__' });
    let afterTest = store.getState();
    return typeof afterTest === 'object' && afterTest.hasOwnProperty('login');
  })()
);

--seed--

--seed-contents--

const defaultState = {
  login: false
};

const reducer = (state = defaultState, action) => {
  // Change code below this line

  // Change code above this line
};

const store = Redux.createStore(reducer);

const loginAction = () => {
  return {
    type: 'LOGIN'
  }
};

--solutions--

const defaultState = {
  login: false
};

const reducer = (state = defaultState, action) => {

  if (action.type === 'LOGIN') {
    return {login: true}
  }

  else {
    return state
  }

};

const store = Redux.createStore(reducer);

const loginAction = () => {
  return {
    type: 'LOGIN'
  }
};