gpt4 book ai didi

reactjs - 使用 redux thunk 的 action creator 和普通的 async function 之间的区别

转载 作者:行者123 更新时间:2023-12-05 05:12:18 25 4
gpt4 key购买 nike

所以我想了解 Redux thunk 的基础知识,我制作了两个 action creator,其中一个可以工作并使用 redux thunk,另一个只使用异步但会中断。下面是屏幕截图:

screenshot

因此,在两个 Action 创建者中,我都等待 API 请求完成,然后返回一个 Action (一个具有类型和负载的 JS 对象)。

但是只有顶部的有效,底部的给出了一个错误,说 Action 必须是普通对象,尽管我返回了一个具有 2 个属性的普通对象。我一直在努力理解为什么第二个 Action 创建者会刹车,如果有人能详细解释为什么会这样,那就太好了。谢谢!

最佳答案

这是因为,当你使用 thunk 时,你返回的不是一个对象就是一个函数。在第二种情况下,当您像这样 dispatch(fetchUser()) 调度您的操作时,它没有返回任何东西,因为您正在调用异步方法。现在 await 下面的代码只会在 async all 完成后执行,原来 dispatch(fetchUser()) 的调用已经完成(提示:只有 await 下面的代码没有执行,但是函数调用已经完成over), fetchUser() 没有返回任何对象,但在第一种情况下,您实际上返回了一个调用异步方法的函数。这就是 thunk 中间件的魔力真正发生的地方。它执行该函数并分派(dispatch)一个由 thunk 执行的 Action (提示:您正在返回一个将分派(dispatch)作为参数的函数)。希望这能消除您的疑虑。我建议您阅读 async/await 的真正工作原理(提示:事件循环/单线程)。

关于reactjs - 使用 redux thunk 的 action creator 和普通的 async function 之间的区别,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54709814/

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