gpt4 book ai didi

reactjs - redux-thunk 调度方法触发未定义的操作

转载 作者:行者123 更新时间:2023-12-03 13:02:32 25 4
gpt4 key购买 nike

这是我正在使用的代码

import { createStore, applyMiddleware } from 'redux'
import thunk from 'redux-thunk'
import axios from 'axios'

const initialState = {
user: {},
requesting: false,
err: null
}

const reducer = (state = initialState, action) => {
switch (action.type) {
case 'REQ_USER_INIT': return { ...state, requesting: true }
case 'REQ_USER_DATA': return { ...state, requesting: false, user: action.user }
case 'REQ_USER_ERR': return { ...state, requesting: false, err: action.err }
}
return state;
}

const logger = (store) => (next) => (action) => {
let previous = JSON.stringify(store.getState())
next(action)
console.log(
'action: ' + JSON.stringify(action) +
'\n\tprevious: ' + previous +
'\n\tcurrent: ' + JSON.stringify(store.getState())
)
}

const store = createStore(reducer, applyMiddleware(logger, thunk))

store.dispatch((dispatch) => {
dispatch({ type: 'REQ_USER_INIT' })

// Fake Online REST API for Testing and Prototyping
// break url to get an error response
let usersEndpoint = 'https://jsonplaceholder.typicode.com/users/1'

axios.get(usersEndpoint)
.then((response) => {
dispatch({
type: 'REQ_USER_DATA',
user: {
id: response.data.id,
username: response.data.username,
email: response.data.email,
}
})
})
.catch((error) => {
dispatch({
type: 'REQ_USER_ERR',
err: error.message
})
})
})

我相信这很简单,对吧?收到响应后,我会调度 REQ_USER_INIT,然后调度 REQ_USER_DATA。我应该记录两个操作,但是我得到了 3 个。第二个操作是 未定义,我正在努力找出导致它的原因。这是 redux-thunk 的错误还是我做错了什么?

这是我的控制台的输出:

action: {"type":"REQ_USER_INIT"}
·previous: {"user":{},"requesting":false,"err":null}
·current: {"user":{},"requesting":true,"err":null}
action: undefined
·previous: {"user":{},"requesting":false,"err":null}
·current: {"user":{},"requesting":true,"err":null}
action: {"type":"REQ_USER_DATA","user":{"id":1,"username":"Bret","email":"Sincere@april.biz"}}
·previous: {"user":{},"requesting":true,"err":null}
·current: {"user":{"id":1,"username":"Bret","email":"Sincere@april.biz"},"requesting":false,"err":null}

最佳答案

中间件的顺序很重要。尝试将logger放在最后

const store = createStore(reducer, applyMiddleware(thunk, logger))

关于reactjs - redux-thunk 调度方法触发未定义的操作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39271923/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com