reactjs - axios - 请求如何改进
reactjs - axios - request how to improve
我有这个请求处于反应状态。两者的目的几乎相同。我在考虑分页,但这个问题却让我感到困惑。关于分别加载两个请求
// use effect loading hooks api responses
useEffect(() => {
const loadNews = async () => {
try {
const response = await api.get('science.json');
const { results } = response.data;
console.log(results);
setScience(results);
} catch (err) {
// Handle Error Here
console.error(err);
}
};
loadNews();
}, []);
useEffect(() => {
const loadNews = async () => {
try {
const response = await api.get('arts.json');
const { results } = response.data;
console.log(results);
setTechnologies(results);
} catch (err) {
// Handle Error Here
console.error(err);
}
};
loadNews();
}, []);
两者都是出于同样的目的,有没有关于两次不相同的代码的解决方案?
我倾向于将获取过程(获取结果)放入它自己的异步函数中。然后,您将使用该函数在 useEffect 中设置结果。
像这样:
async function fetchNews(jsonFile) {
const response = await api.get(jsonFile);
const { results } = response.data;
return results;
}
useEffect(() => {
fetchNews("science.json")
.then(res => setScience(res))
.catch(err => console.error(err))
fetchNews("arts.json")
.then(res => setTechnologies(res))
.catch(err => console.error(err))
}, []);
这可能是
useEffect(() => {
loadNews("arts.json", setScience);
loadNews("science.json", setTechnologies);
}, []);
const loadNews = async (url, callBack) => {
try {
const response = await api.get(url);
const { results } = response.data;
console.log(results);
callBack(results);
} catch (err) {
// Handle Error Here
console.error(err);
}
}
我有这个请求处于反应状态。两者的目的几乎相同。我在考虑分页,但这个问题却让我感到困惑。关于分别加载两个请求
// use effect loading hooks api responses
useEffect(() => {
const loadNews = async () => {
try {
const response = await api.get('science.json');
const { results } = response.data;
console.log(results);
setScience(results);
} catch (err) {
// Handle Error Here
console.error(err);
}
};
loadNews();
}, []);
useEffect(() => {
const loadNews = async () => {
try {
const response = await api.get('arts.json');
const { results } = response.data;
console.log(results);
setTechnologies(results);
} catch (err) {
// Handle Error Here
console.error(err);
}
};
loadNews();
}, []);
两者都是出于同样的目的,有没有关于两次不相同的代码的解决方案?
我倾向于将获取过程(获取结果)放入它自己的异步函数中。然后,您将使用该函数在 useEffect 中设置结果。
像这样:
async function fetchNews(jsonFile) {
const response = await api.get(jsonFile);
const { results } = response.data;
return results;
}
useEffect(() => {
fetchNews("science.json")
.then(res => setScience(res))
.catch(err => console.error(err))
fetchNews("arts.json")
.then(res => setTechnologies(res))
.catch(err => console.error(err))
}, []);
这可能是
useEffect(() => {
loadNews("arts.json", setScience);
loadNews("science.json", setTechnologies);
}, []);
const loadNews = async (url, callBack) => {
try {
const response = await api.get(url);
const { results } = response.data;
console.log(results);
callBack(results);
} catch (err) {
// Handle Error Here
console.error(err);
}
}