使用 React、Redux-thunk 进行 API 调用的最佳位置在哪里?
我已经检查了stackoverflow.com以及整个互联网的类似问题,但没有找到任何问题,因此请忽略,如果您找到一个人,请不要享有负面的声誉,因为我在一生中需要声誉!
我的代码工作正常,但我想知道为什么在动作创建器文件中调用API请求不是一个好练习,什么是替代方法?
mycomponent.jsx
const MyComponent = () => {
dispatch = useDispatch();
return <div>
<button onClick={()=>{
dispatch(getItems("?color=xxx&manufacturer=yyy"));
}}></button>
</div>
}
ActionCreator.js
const getItems = (queryString) => async (dispatch) => {
try{
dispatch({
type: "FETCH_REQUEST",
});
// >>>>>> Here is the problem! <<<<<<
const response = await fetch("https://subname.name.com/api/" + queryString);
const data = await response.json();
dispatch({
type: "FETCH_SUCCESS",
payload: data,
});
}catch(error){
dispatch({
type: "FETCH_FAILURE",
payload: error,
});
}
}
降低>降低> JS
const INITIAL_STATE = {
items: [],
isLoading: false,
error: "",
};
const reducer = (currentState, action) => {
switch(action.type){
case: "FETCH_REQUEST":
return {
...currentState,
isLoading: true,
};
case: "FETCH_SUCCESS":
return {
...action.payload,
isLoading: false,
};
case: "FETCH_FAILURE":
return {
items: [],
error: "An error happend when fetching main data.",
};
}
}
I've already checked StackOverflow.com and also the entire internet for a similar question and didn't find any, so please ignore and do not give a negative reputation if you find one as I need reputation in this moment of my life!
My code works fine but I would like to know why calling an API request inside the Action-Creator file is not a good practice and what is the replacement for it?
MyComponent.jsx
const MyComponent = () => {
dispatch = useDispatch();
return <div>
<button onClick={()=>{
dispatch(getItems("?color=xxx&manufacturer=yyy"));
}}></button>
</div>
}
ActionCreator.js
const getItems = (queryString) => async (dispatch) => {
try{
dispatch({
type: "FETCH_REQUEST",
});
// >>>>>> Here is the problem! <<<<<<
const response = await fetch("https://subname.name.com/api/" + queryString);
const data = await response.json();
dispatch({
type: "FETCH_SUCCESS",
payload: data,
});
}catch(error){
dispatch({
type: "FETCH_FAILURE",
payload: error,
});
}
}
Reducer.js
const INITIAL_STATE = {
items: [],
isLoading: false,
error: "",
};
const reducer = (currentState, action) => {
switch(action.type){
case: "FETCH_REQUEST":
return {
...currentState,
isLoading: true,
};
case: "FETCH_SUCCESS":
return {
...action.payload,
isLoading: false,
};
case: "FETCH_FAILURE":
return {
items: [],
error: "An error happend when fetching main data.",
};
}
}
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
我相信这主要取决于您想要做什么以及数据的用例是什么。
例如,如果您尝试获取用户数据以确定身份验证或授权,则应该使请求尽可能高,
然而,如果您尝试获取仅在边缘情况下严格需要的数据,那么使用带有事件侦听器的按钮应该没问题。
另一种选择是在 useEffect 中使用分派或使用专用于执行此操作的回调函数。
由于缺乏声誉,我无法将其作为评论,但我询问了一位更有经验的开发人员,从我收集到的信息来看,我得到的一般答复是 - 这实际上取决于数据用例。
I believe it is mainly based on what you're trying to do and what is the use case of the data.
for example, if you were trying to fetch user data to determine authentication or authorization, you should make the request as high as possible,
whereas, if you are trying to fetch data that is only strictly needed on edge cases, using a button with an event listener should be fine.
Another option is using dispatch within useEffect or using a callback function dedicated to doing that.
I couldn't put it as a comment due to lack of reputation, but I've asked a more experienced developer and from what I could gather, the general response I got was - it's really depending on the data use case.
您现在可以与RTK查询一起使用Redux工具包
他们还建议使用
这些技术使用Typescript,这将使您的代码更加简洁。
RTK查询此处
,然后使用此挂钩在组件中使用它
您应该阅读文档
在此Architechture中,Redux Toolkit做了与您所做的相同的事情。
我也用这种方式做的架构没有错。
You can Now use Redux ToolKit alongwith RTK query
They also recommend to Use Typescript Nowadays
Using These Technologies will make your code more concise.
RTK query here
then use it in your component using this hook
You should read the Documentation
In this architechture redux toolkit does the same thing you did.
There is nothing wrong with your architechture I also used to do it that way.