Reactjs 组件异步获取redux状态?
我对redux州有问题。分页组件具有该方法Reactjs 组件异步获取redux状态?,reactjs,redux,react-redux,Reactjs,Redux,React Redux,我对redux州有问题。分页组件具有该方法 const setPage = page => { props.removeFilterParam('page'); props.addFilterParam('page', page); props.getProducts(); } props.removeFilterParam和props.addFilterParam是修改redux存储的redux操作,getProducts是父组件上的方法,如下所示 async
const setPage = page => {
props.removeFilterParam('page');
props.addFilterParam('page', page);
props.getProducts();
}
props.removeFilterParam
和props.addFilterParam
是修改redux存储的redux操作,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);
}
}
父组件与redux存储连接。当在控制台中调用getProducts
时,我看到:
因此,在通过addFilterParam
修改redux状态后,这些更改不会同步应用于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;
}
}
Redux操作不是同步的。他们不会在飞行中改变你的组件道具。它们所做的是触发一个可以改变减速器的动作(就像react
setState
,)。它们肯定会在下一次调用render()
时更改。如果需要在道具更改时收到通知,可以使用回调。在您的示例中:
componentDidUpdate(prevProps) {
const { filter } = this.props
if (filter !== prevProps.filter) {
// filter changed
console.log('Filter changed', filter)
}
}