gpt4 book ai didi

javascript - 有哪些常见的 Redux Toolkit 的 CreateAsyncThunk 用例

转载 作者:行者123 更新时间:2023-12-04 00:18:31 27 4
gpt4 key购买 nike

有人可以像我 9 岁那样向我解释什么以及如何使用 createAsyncThunk 吗? Action 字符串有什么用?它是出于逻辑/路径原因临时创建并很快销毁吗?我可以用操作字符串做什么/人们通常用它做什么?我一直盯着文档看,我无法理解。

这就是其他人使用代码的方式,如果有人能破译这个我会很高兴。

const action = createAsyncThunk('send/sendAction', async (form, thunkAPI) => {
const data = await axios.post('/api', object);
data.reduxRequestId = thunkAPI.requestId;
return data;
}

官方文档: https://redux-toolkit.js.org/api/createAsyncThunk

最佳答案

好吧,您可以将 Async Thunk 函数和 Reducer 函数划分为单独的类型。
它们并不完全相同,您应该注意到这一点。

Reducer 函数不能执行异步代码,它们可以执行代码并更新状态,但是如果你想从服务器获取或更新一些东西,然后更新 Redux 状态,你将无法单独使用 reducer 来实现功能。

所以,这就是我们需要 Action 创建者(或 AsyncThunk 函数)的原因,它让我们能够执行异步代码,然后更新 Redux 的实际状态。

const action = 

您定义一个常量,它接收(在这种情况下)另一个函数,它是 createAsyncThunk它接收两个参数,第一个参数 action type第二个是 payloadCreator callback
const action = createAsyncThunk('send/sendAction', async (form, thunkAPI) => {

所以在这种情况下 action接收预定义的对象 (createAsyncThunk)。

如果你还记得,要使用 reducer 函数,你通常需要两个参数,一个是 actionType第二个是 payload .

使用 createAsyncThunk 它接收的第一个参数是 actionType,它是 'send/sendAction'这是你的 reducer 将接收的 actionType,接收两个参数的异步部分是有效负载生成器。
const action = createAsyncThunk('send/sendAction', async (form, thunkAPI) => {
const data = await axios.post('/api', object);
data.reduxRequestId = thunkAPI.requestId;
return data;
}

函数 createAsyncThunk 返回两个参数,一个是 actionType第二个是 Payload正是您需要执行 reducer 功能的那些。

现在如果你想使用你的方法应该是这样的。
dispatch(action(formValuesFromLocalState, APIInstance));

在这种情况下,您传递给该函数的参数或参数(formValuesFromLocalState 和 APIInstance)将传递给异步函数,因此它们将是这样的
const action = createAsyncThunk('send/sendAction', async (form = formValuesFromLocalState, thunkAPI = APIInstance) 

使用这些参数,您的方法将执行或您可能想要执行的方式应该是这样的。
const action = createAsyncThunk('send/sendAction', async (form, thunkAPI) => {
const object = /some specific way you want to morph the form values/
const data = await axios.post('/api', object);
data.reduxRequestId = thunkAPI.requestId;
return data; (this is the actual data which will be returned as a payload).
}

在文档中,他们举了一个更好的例子

他们以这种方式执行功能:
dispatch(fetchUserById(123))

实际功能是:
const fetchUserById = createAsyncThunk(
'users/fetchByIdStatus',
async (userId, thunkAPI) => {
const response = await userAPI.fetchById(userId)
return response.data
}
)

因此,该函数仅在这种情况下接收 userId , thunkAPI未使用。
'users/fetchByIdStatus'

是将被分派(dispatch)的 actionType。
const response = await userAPI.fetchById(userId)
return response.data

API调用是异步代码,返回语句 return response.data是实际的有效载荷。

所以最后,调度函数可能看起来像这样:
dispatch({type:'users/fetchByIdStatus', payload:(whatever response.data has)});

希望这个解释是可以理解的,请原谅我的英语不好。

关于javascript - 有哪些常见的 Redux Toolkit 的 CreateAsyncThunk 用例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62368296/

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