[英]action.type undefined in redux
我有一个 redux 错误:action.type 未定义。 我已将其缩小为我的一项行动:
export function LOAD_PRODUCTS() {
axios.get('http://localhost:3000/api/products')
.then((res) => {
return (dispatch) => {
dispatch({type: 'PRODUCTS_LOADED', payload: res})
}
})
.catch((err) => {
return (dispatch) => {
dispatch({type: "PRODUCTS_ERROR", payload: err})
}
})
}
或者也许是减速机...
export function reducer(
state = {
fbkey: '',
userSuccess: null,
cart: [],
nav: null,
tab: true,
error: {},
loading: false,
products: []
}, action) {
switch (action.type) {
case "FBTOKEN": {
return {
...state,
fbkey: action.payload
}
}
case "NAV_OPEN" : {
return {
...state,
nav: true
}
}
case "NAV_CLOSE" : {
return {
...state,
nav: false
}
}
case "USER_SUCCESS" : {
return {
...state,
userSuccess: true
}
}
case "USER_ERROR" : {
return {
...state,
userSuccess: false
}
}
case "ADD_TO_CART" : {
return {
...state,
cart: action.payload
}
}
case "TAB_CLOSE": {
return {
...state,
tab: action.payload
}
}
case "TAB_OPEN": {
return {
...state,
tab: action.payload
}
}
case "PRODUCTS_LOADED": {
return {
...state,
products: action.payload
}
}
case "PRODUCTS_ERROR": {
return {
...state,
error: action.payload
}
}
case "IS_LOADING": {
return {
...state,
loading: action.payload
}
}
case "IS_NOT_LOADING": {
return {
...state,
loading: action.payload
}
}
default: {
return {
...state
}
}
}
}
所以,不知何故类型没有被正确返回。 我该如何解决?
编辑:这里正在使用 Thunk。 我还添加了减速器代码.. 返回调度函数也不起作用。 或许与此有关?
您需要返回调度尝试下面的代码
export function LOAD_PRODUCTS() {
axios.get('http://localhost:3000/api/products')
.then((res) => {
return (dispatch) => {
return dispatch({type: 'PRODUCTS_LOADED', payload: res})
}
})
.catch((err) => {
return (dispatch) => {
return dispatch({type: "PRODUCTS_ERROR", payload: err})
}
})
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.