Files

4.2 KiB
Raw Permalink Blame History

id, title, challengeType, forumTopicId, dashedName
id title challengeType forumTopicId dashedName
5a24c314108439a4d4036150 Обробка дії в сховищі 6 301444 handle-an-action-in-the-store

--description--

Після того, як дія була створена та відправлена, сховище Redux мусить знати, як відповідати на цю дію. Це — завдання для функції reducer. Зменшувачі в Redux відповідають за стан змін, які відбуваються у відповідь на дії. reducer використовує state та action як аргументи, і це завжди повертає новий state. Важливим є те, що це — єдина роль зменшувача. У нього немає побічних дій — він не викличе кінцеву точку API й не має підводних каменів. Зменшувач — це просто чиста функція, яка використовує стан і дію та повертає новий стан.

Іншим ключовим принципом Redux є те, що state — тільки для читання. Іншими словами, функція reducer мусить завжди повертати нову копію state і ніколи не змінювати безпосередньо стан. Redux не забезпечує незмінність стану, щоправда, ви відповідаєте за його забезпечення у вашому коді та функціях зменшувача. Ви зможете попрактикуватись у цьому в наступних завданнях.

--instructions--

Редактор коду має попередній приклад, точно так само, як і початок функції reducer для вас. Заповніть основну частину функції reducer так, щоб, якщо вона отримає дію типу 'LOGIN', то поверне об'єкт з набором login для true. В іншому випадку, вона поверне поточний state. Зверніть увагу, що поточний state та відправлена action підходять для зменшувача, то ж ви зможете отримати доступ безпосередньо до типу дії з action.type.

--hints--

Виклик функції loginAction повинен повертатися як об'єкт з типом набору параметрів для рядка LOGIN.

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

Сховище мусить бути ініціалізованим з об'єктом, що має параметр login, встановлений на false.

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

Відправлення loginAction мусить оновити параметр login у сховищі, до стану true.

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

Якщо дія не є типом LOGIN, то сховище мусить повернути поточний стан.

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'
  }
};