state
, но сначала рассмотрим все, что вы изучили до сих пор. incAction
и decAction
, редуктор counterReducer()
, типы действий INCREMENT
и DECREMENT
, и, наконец, Redux хранилище store
. После того, как вы закончите , вы должны смочь отправить действия INCREMENT
или DECREMENT
для увеличения или уменьшения состояния в хранилище store
. Удачи в создании вашего первого приложения Redux! incAction
должен возвращать объект действия с type
равным значению INCREMENT
testString: 'assert(incAction().type ===INCREMENT, "The action creator incAction
should return an action object with type
equal to the value of INCREMENT
");'
- text: Создатель действия decAction
должен возвращать объект действия с type
равным значению DECREMENT
testString: 'assert(decAction().type === DECREMENT, "The action creator decAction
should return an action object with type
equal to the value of DECREMENT
");'
- text: Хранилище Redux должно инициализироваться состоянием state
равным 0.
testString: 'assert(store.getState() === 0, "The Redux store should initialize with a state
of 0.");'
- text: Отправка incAction
в хранилище Redux должна увеличивать state
на 1.
testString: 'assert((function() { const initialState = store.getState(); store.dispatch(incAction()); const incState = store.getState(); return initialState + 1 === incState })(), "Dispatching incAction
on the Redux store should increment the state
by 1.");'
- text: Отправка decAction
в хранилище Redux должна уменьшать state
на 1.
testString: 'assert((function() { const initialState = store.getState(); store.dispatch(decAction()); const decState = store.getState(); return initialState - 1 === decState })(), "Dispatching decAction
on the Redux store should decrement the state
by 1.");'
- text: counterReducer
должен быть функцией
testString: 'assert(typeof counterReducer === "function", "counterReducer
should be a function");'
```