3.2 KiB
id, title, challengeType, forumTopicId, dashedName
| 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'
}
};