In this post, I’ll demo how to read a value from a promise using use
.
Links
Snippet
Let’s check out the following code:
import { Suspense } from "react";
export default function Page() {
const messagePromise = fetchMessages();
return (
<Suspense fallback={<p>⌛ waiting for messages...</p>}>
<Message messagePromise={messagePromise} />
</Suspense>
);
}
A couple of things to note:
<Suspense />
is being used, which basically displays the fallback, in this case:⌛ waiting for messages...
, until the promise is resolved.messagePromise
is a promise passed as a prop to<Message />
.
Now, let’s take a look at fetchMessages
:
async function fetchMessages() {
return [
{
id: 1,
text: "message 1",
},
{
id: 2,
text: "message 2",
},
];
}
As you can see, it’s a very simple function. In a real world example, this could be a fetch
request, but for simplicity, the function just returns an array. By using async
, JavaScript automatically knows that the function returns a promise.
Finally, let’s check out the <Message>
component:
function Message({ messagePromise }) {
const comments = use(messagePromise);
return comments.map((comment) => <p key={comment.id}>{comment.text}</p>);
}
This is where it gets interesting. The <Message>
component receives messagePromise
as a prop, which, as we mentioned, is a promise.
Usually, you’d use await
with a promise, but in React 19, you can now use use
to achieve basically the same result.
One key difference between
await
anduse
is thatawait
blocks rendering until the promise is resolved, whereasuse
doesn’t block rendering.
Here’s how the component looks before the promise is resolved:
And once the promise is resolved:
Conclusion
use
works similarly to await
, and if the application is running on a server using SSR, the result is exactly the same: the server will return the same HTML response in both cases.
However, if the code runs on the client, rendering behaves a bit differently. await
blocks rendering until the promise is resolved, while use
allows the component to re-render once the promise is resolved.
Top comments (3)
What will be the output if we use await here , will there be any difference ??
Hi @deepansh_johri_cc5bd700a7 ,
Message
is a React component, and typically you would have something like this:Notice: that
messagePromise
is already a returned promise value from a function.So instead of using the
async
function modifier andawait
, React 19 now lets you resolve the promise withuse
In terms of output, it might depend on where the code is executed: Server vs. Client. However, ultimately, the result will be the same
Additionally, @tim_goyer_b3415aeb32d74e5 is right about the case when "inside the body of useEffect"
You can't have an async hook.
This fixes the issue with writing an async function inside the body of useEffect and then immediately calling it.