我希望能调用异步函数并在UseEffect中获取结果。
我在网上找到的fetch api示例直接放在了useEffect函数中。 如果我的URL改变了,我必须修改所有的fetch。
当我尝试时,出现了错误消息。
这是我的代码。
我在网上找到的fetch api示例直接放在了useEffect函数中。 如果我的URL改变了,我必须修改所有的fetch。
当我尝试时,出现了错误消息。
这是我的代码。
async function getData(userId) {
const data = await axios.get(`http://url/api/data/${userId}`)
.then(promise => {
return promise.data;
})
.catch(e => {
console.error(e);
})
return data;
}
function blabla() {
const [data, setData] = useState(null);
useEffect(async () => {
setData(getData(1))
}, []);
return (
<div>
this is the {data["name"]}
</div>
);
}
index.js:1375 警告:效果函数除了用于清理的函数外,不应返回任何内容。 看起来你写了 useEffect(async () => ...) 或者返回了一个 Promise。相反,应该在 effect 内部编写 async 函数并立即调用它:
useEffect(() => {
async function fetchData() {
// You can await here
const response = await MyAPI.getData(someId);
// ...
}
fetchData();
}, [someId]); // Or [] if effect doesn't need props or state
await
或.then(...)
,但不能同时使用。 - Omagerio