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: Dispatching 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 должна decAction
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");'
```