I'm doing a fetch in my api and it returns a 201 status, but when I try to receive it in a variable, the status becomes weird.
useEffect(() => { async function Verify (test) { await fetch("/api/test", { method: "POST", headers: { 'Content-Type': 'application/json', }, body: JSON.stringify({test: test}), }).then((response) => { res = response.status; console.log(res); //thats print '201' return res; }); } const status = Verify(test); console.log(status); //thats print 'Promise { : "fulfilled", : 201 }' }
If you want
statusto be equal to the result ofVerify, you need toawaitit.Additionally, I recommend refactoring your code to use
awaiteverywhere to simplify the process. Try something like this:async function Verify (test) { const res = await fetch('/api/test', { method: 'POST', headers: { 'Content-Type': 'application/json', }, body: JSON.stringify( { test } ), }); if (!res.ok) { throw new Error('Not-ok response from server'); } return res; }