У меня проблема с избыточным состоянием.Компонент нумерации страниц имеет метод
const setPage = page => {
props.removeFilterParam('page');
props.addFilterParam('page', page);
props.getProducts();
}
props.removeFilterParam
и props.addFilterParam
- действия с избыточностью, которые изменяют хранилище с избыточностью, getProducts
- метод на родительском компоненте, который выглядит следующим образом
async getProducts() {
try {
console.log('Filter before', this.props.filter);
setTimeout(() => console.log('After', this.props.filter), 2000)
// const slug = this.props.match.params.slug;
// const queryString = transformToQueryString(this.props.filter);
// await this.props.getProductsRequest(`/api/categories/${slug}/${queryString}`);
} catch (error) {
console.error(error);
}
}
Родительский компонент связан с избыточным хранилищем.Когда в консоли вызывается getProducts
, я вижу это:
Таким образом, после изменения состояния избыточности с помощью addFilterParam
изменения не применяются вgetProducts
работает синхронно.
Действия:
export const addFilterParam = (name, value) => ({
type: ADD_FILTER_PARAM,
name,
value
})
export const removeFilterParam = (name, value) => ({
type: REMOVE_FILTER_PARAM,
name,
value
});
Редуктор:
const filterReducer = (state = {}, action) => {
switch(action.type) {
case ADD_FILTER_PARAM:
if (state.hasOwnProperty(action.name)) {
if (Array.isArray(action.value)) {
state[action.name] = [...state[action.name], ...action.value];
} else {
if (state[action.name].indexOf(action.value) === -1) {
state[action.name].push(action.value);
}
}
} else {
if (Array.isArray(action.value)) {
state[action.name] = action.value;
} else {
state[action.name] = [action.value];
}
}
return {...state};
case REMOVE_FILTER_PARAM:
if (state.hasOwnProperty(action.name)) {
if (action.value) {
let args = state[action.name];
const index = args.indexOf(action.value);
if (index !== -1) {
args.splice(index, 1);
if (args.length) {
state[action.name] = args;
} else {
delete state[action.name];
}
}
} else {
delete state[action.name];
}
}
return {...state};
case CLEAR_FILTER:
return {};
default: return state;
}
}