Next.js 13: Data Fetching Strategies

Rate this content
Bookmark
Github

- Introduction

- Prerequisites for the workshop

- Fetching strategies: fundamentals

- Fetching strategies – hands-on: fetch API, cache (static VS dynamic), revalidate, suspense (parallel data fetching)

- Test your build and serve it on Vercel

- Future: Server components VS Client components

- Workshop easter egg (unrelated to the topic, calling out accessibility)

- Wrapping up

This workshop has been presented at React Day Berlin 2022, check out the latest edition of this React Conference.

FAQ

Vercel is a company that created and maintains several developer tools including Next.js, Webpack, TurboPack, and TurboRepo. They specialize in solutions for developers and offer tools that enhance web development workflows.

The React Day Berlin workshop focuses on data fetching strategies for the new App Directory in Next.js, including server components, client components, dynamic fetching, ISR (Incremental Static Regeneration), and streaming.

Server components in Next.js are components that run on the server and are statically generated by default. They fetch data on the server side, reducing the need for client-server round trips and improving performance.

Client components in Next.js are used for functionalities that require the client-side environment, such as using React hooks like useState or useEffect. They are useful for dynamic interactions and real-time data updates.

Incremental Static Regeneration (ISR) allows you to create or update static pages after the site has been built. It enables the regeneration of static content at runtime without rebuilding the entire site, based on a defined revalidation period.

On-Demand ISR (Incremental Static Regeneration) allows developers to manually trigger the regeneration of static pages by calling an API endpoint. This is useful for scenarios where content updates need to be reflected immediately, rather than waiting for the next scheduled regeneration.

Streaming in Next.js allows different parts of a page to be rendered and sent to the client independently. Using React's Suspense, sections of the UI can be streamed to the client as they are ready, improving the perceived load time and user experience.

For the Next.js workshop, it is recommended to use an IDE like Visual Studio Code, a terminal, and tools such as Yarn for package management. A Vercel ProTrial account may also be useful for accessing preview comments and deployment features.

You can provide feedback or ask questions about the workshop content by commenting on the specific GitHub branch or URL provided during the workshop. If logged into Vercel, you can comment directly on the page, and the feedback will be reviewed and responded to by the Vercel team.

Dynamic fetching in Next.js can be implemented by setting the cache option to 'no store' in the fetch request. This ensures that the data is fetched fresh on every request, bypassing any caching mechanisms.

Alice De Mauro
Alice De Mauro
53 min
12 Dec, 2022

Comments

Sign in or register to post your comment.
Video Summary and Transcription
This workshop at React Day Berlin covered fetching strategies for the new App Directory, including server components, client components, and dynamic fetching. Next.js introduced powerful fetching strategies like ISR and on-demand ISR, along with other enhancements in Next 13. The workshop emphasized the importance of setting up a development environment and creating a production build for testing. It also discussed the benefits of using caching and revalidating strategies in Next.js for efficient data fetching. The workshop concluded with a focus on streaming with suspense for independent streaming of UI components and enhancing interactivity for users.

1. Introduction to Workshop and Fetching Strategies

Short description:

Welcome to our workshop, React Day Berlin. I'm Alice De Mauro, a sales engineer at Vercell. We'll cover fetching strategies for the new App Directory, including server components, client components, and dynamic fetching.

Hello, everybody. Welcome to our workshop, React Day Berlin, about 9CX13 and data fetching especially for what concerns the new app directory. I'm Alice De Mauro, I'm a sales engineer at Vercell, and a sales engineer means basically that I am a solution architect for pre-sales.

So basically, I check the architecture of our customers and I see if Vercell is a fee. What is Vercell? If you don't know it, we created and are maintaining SGS. Webpack, we have people working from Webpack and we just released TurboPack. We do also have in-house TurboRepo and other tools that might be useful for developers, in general, if you don't know us, we are the creator of the legendary Next.js, which is the framework for React.

I'm going to immediately start with what are our prerequisite basically or what at least I'm going to use for you workshop. Something that I'm going to do pretty often is this movement here. I hope it's not too jarring, but I'm really used to go for my environment like that. What do I have? I have my ID. I have my terminal and my Visual Studio code. I do already have some code prepared. The code is going to be at this place.

I'm going to actually give you two links. One is going to be the clean code before the workshop basically. I'm going to drop it in the chat. This is public and you can just access it. I simply forked one of our famous repositories for the playground for Next.js app and just tweaked it for this workshop specifically. What I'm going to do is to actually use the pull request to welcome to our workshop in order to paste or to deploy our changes. All the changes I'm going to make, you're going to see them in this specific GitHub branch. What also I'm going to do, I have my Vercel dashboard. I created a ProTrial just for this workshop. Why? Because I needed it to have all preview comments enabled for you. If I go on my deployments, I have my preview. My preview is based on the welcome to the workshop branch. Basically, here I'm now going to paste this one. If you are logged in in Vercel, you got to paste it here. If you can login in Vercel, then you are able to actually comment on everything that is on this page. This is going to be our workshop baseline.

For example, I can do this example. I'm going to see your comments. If you don't have Vercel yet, consider that I had OBI just, I don't know, yesterday. I think yesterday I had OBI. It's super easy, you just continue with GitHub, you just login into GitHub and done. Same for GitHub and Bitbucket. Then you can comment on this specific URL. This URL will also leave after the workshop. Don't worry about eventually things that you forgot to ask or that you don't want to ask now because you want to check things further later on. Please just go here and comment. I'm going to receive them directly on here. Then the comments, they're going to see them on the Versal bot. I'm going to simply check them here. I think for what concerns what we're going to have, more or less, ready, it's done.

Something else. What is it all about? Our workshop will be about fetching strategies for the new App Directory. I'm going to show you server components, which is basically the default for the new Next.js. Client components and how to do it on SUR. Disclaimer is like you did it before, nothing different. Dynamic fetching, and how does it work when you opt-in, when you opt-out, and these kind of things.

2. Fetching Strategies and Server Components

Short description:

ISR and on-demand ISR are powerful fetching strategies. React Day Berlin just released Next 13, along with other enhancements. The Beta docs are available for feedback. Setting up a development environment and creating a production build are important for testing. The app directory in the new NestJS directory reflects the routes. Server components are always rendered first on the server and are fetched at build time, eliminating the need for round trips between client and server.

ISR, we provide that out of the box. It's pretty powerful. If you didn't try it, try it. On-demand ISR, powerful again, very, very powerful. That's probably the longest piece, because to set up on-demand ISR is a little bit more work, not too much, but still, but that's gonna be our most longest probably, and then how streaming works. So our suspense works in general, because that's from React, and how it will work together with Pagesy. These are all fetching strategy, can be like from the data perspective, they are tightly coupled with the page perspective, is also how the pages and the routes are rendered basically.

Just so you know, if you don't know Next, or you never used it, we just released Next 13. The app directory is not the only thing that we released, of course. There's gonna be also a lot of others, for example, TurboPack, or the image, the font, and so on, the scripts, all integrated and enhanced. So if you don't know, or you want to check more, just, you know, I pasted there the link. We also have the, I'm gonna fetch them right now, the Beta, this is specific to the fetching, data fetching strategy. But in general, we do have the Beta docs. If you are logged in in Vercel, you also can comment on them. So if you find something that is not clear, please give us feedback, you know, anything that is useful to enhance our docs, it's always good, especially if you're expecting something that's not there, please just don't be afraid to paste a comment there, you just click on these little icon and you can just comment. And we answer, so if there is some, you know, things that it's not clear on the docs, we do answer questions in general.

So back to the code. So I have my IDE here and I'm gonna have some code already done because of course, part of the fact that I'm very clumsy with my hands, so I tend to do a lot of typos, but apart of that, it's easier, it's faster, it's gonna be faster to actually paste the code from something that's already created, I'm gonna push this code anyway, so you're gonna have it on the GitHub account. First thing first, so, terminal, a nice terminal, two things that are very important. Of course, first thing first, you have to install everything, you're gonna use YARN. I usually use npm, while in my developer careers, I use npm all the time, but these days I don't know, I like YARN pretty much, so I'm using YARN for now, if you run YARN dev, so these are the two distinctive things that are very important. If you use YARN dev, you're gonna spin up the dev environment, which is the server-side rendering environment with hot reloading, so every time you change something, maybe super fast, and localhost, I'm gonna show you right now because I have localhost here, on localhost is gonna always show my changes right away whenever I do any change. Something that we're gonna use later on is really, really important to test all our fetching strategy, especially for what concerns the statically generated pages and the static fetching in general, is gonna be creating a production build. I'm gonna go right away to it because server components is one of these examples where if you have anything that you need to test from the static perspective, you will need to create a production environment and test there, because only there, you actually have the classic first build and then serve, right? For now I'm just gonna start right away. So I have my application here, the app directory is the new NestJS directory. I have everything in the package of JSON of course, and I do have some groupings. These groupings are not gonna be in your routing, they're just meant to tidy, to tie, sorry, your URL. So basically what I did was like, okay, I have a couple of fallbacks because it's of the loading pages and so on. Some youtube that I might or might not use, but what is important is our fetching. So from the root directory, localhost slash, we're gonna go through all these routing. Every single route is gonna be reflected from these names from the folders. This the same way a classic NestJS works. So server component is gonna be one of my routes and this is where I'm gonna start. I'm gonna go to my local host. So if I click on server components, which is the first one, you see server component is my, my route. So the name of the folder, exactly the name of the folder automatically done from next. Server components. So explanation of server components. They are running the server. They are gonna be always automatic. Pages and layouts are always, always server components. Always, they're gonna always be rendered first in the server. I will show you later on client components and, you know, how to divide the little pieces. By default they are steadily generated at build time. And that means that everything is gonna be fetched at the time you're gonna be fetched from the server. There is not gonna be any round trip from the client and the server. So there's not gonna be such a thing like, oh, I have the client, I have all my JavaScript and then I need the posts of my blog posts, right? And then I have to ask back and forth to the server. No give me this one, give me that one. So that's not gonna happen because everything is in the server, within the server and the server is gonna do all these kinds of fetchings without any round trip between client and server. And that's super, super fast because then they're already built.

Watch more workshops on topic

React Performance Debugging Masterclass
React Summit 2023React Summit 2023
170 min
React Performance Debugging Masterclass
Top Content
Featured WorkshopFree
Ivan Akulov
Ivan Akulov
Ivan’s first attempts at performance debugging were chaotic. He would see a slow interaction, try a random optimization, see that it didn't help, and keep trying other optimizations until he found the right one (or gave up).
Back then, Ivan didn’t know how to use performance devtools well. He would do a recording in Chrome DevTools or React Profiler, poke around it, try clicking random things, and then close it in frustration a few minutes later. Now, Ivan knows exactly where and what to look for. And in this workshop, Ivan will teach you that too.
Here’s how this is going to work. We’ll take a slow app → debug it (using tools like Chrome DevTools, React Profiler, and why-did-you-render) → pinpoint the bottleneck → and then repeat, several times more. We won’t talk about the solutions (in 90% of the cases, it’s just the ol’ regular useMemo() or memo()). But we’ll talk about everything that comes before – and learn how to analyze any React performance problem, step by step.
(Note: This workshop is best suited for engineers who are already familiar with how useMemo() and memo() work – but want to get better at using the performance tools around React. Also, we’ll be covering interaction performance, not load speed, so you won’t hear a word about Lighthouse 🤐)
React Hooks Tips Only the Pros Know
React Summit Remote Edition 2021React Summit Remote Edition 2021
177 min
React Hooks Tips Only the Pros Know
Top Content
Featured Workshop
Maurice de Beijer
Maurice de Beijer
The addition of the hooks API to React was quite a major change. Before hooks most components had to be class based. Now, with hooks, these are often much simpler functional components. Hooks can be really simple to use. Almost deceptively simple. Because there are still plenty of ways you can mess up with hooks. And it often turns out there are many ways where you can improve your components a better understanding of how each React hook can be used.You will learn all about the pros and cons of the various hooks. You will learn when to use useState() versus useReducer(). We will look at using useContext() efficiently. You will see when to use useLayoutEffect() and when useEffect() is better.
React, TypeScript, and TDD
React Advanced 2021React Advanced 2021
174 min
React, TypeScript, and TDD
Top Content
Featured WorkshopFree
Paul Everitt
Paul Everitt
ReactJS is wildly popular and thus wildly supported. TypeScript is increasingly popular, and thus increasingly supported.

The two together? Not as much. Given that they both change quickly, it's hard to find accurate learning materials.

React+TypeScript, with JetBrains IDEs? That three-part combination is the topic of this series. We'll show a little about a lot. Meaning, the key steps to getting productive, in the IDE, for React projects using TypeScript. Along the way we'll show test-driven development and emphasize tips-and-tricks in the IDE.
Designing Effective Tests With React Testing Library
React Summit 2023React Summit 2023
151 min
Designing Effective Tests With React Testing Library
Top Content
Featured Workshop
Josh Justice
Josh Justice
React Testing Library is a great framework for React component tests because there are a lot of questions it answers for you, so you don’t need to worry about those questions. But that doesn’t mean testing is easy. There are still a lot of questions you have to figure out for yourself: How many component tests should you write vs end-to-end tests or lower-level unit tests? How can you test a certain line of code that is tricky to test? And what in the world are you supposed to do about that persistent act() warning?
In this three-hour workshop we’ll introduce React Testing Library along with a mental model for how to think about designing your component tests. This mental model will help you see how to test each bit of logic, whether or not to mock dependencies, and will help improve the design of your components. You’ll walk away with the tools, techniques, and principles you need to implement low-cost, high-value component tests.
Table of contents- The different kinds of React application tests, and where component tests fit in- A mental model for thinking about the inputs and outputs of the components you test- Options for selecting DOM elements to verify and interact with them- The value of mocks and why they shouldn’t be avoided- The challenges with asynchrony in RTL tests and how to handle them
Prerequisites- Familiarity with building applications with React- Basic experience writing automated tests with Jest or another unit testing framework- You do not need any experience with React Testing Library- Machine setup: Node LTS, Yarn
Master JavaScript Patterns
JSNation 2024JSNation 2024
145 min
Master JavaScript Patterns
Top Content
Featured Workshop
Adrian Hajdin
Adrian Hajdin
During this workshop, participants will review the essential JavaScript patterns that every developer should know. Through hands-on exercises, real-world examples, and interactive discussions, attendees will deepen their understanding of best practices for organizing code, solving common challenges, and designing scalable architectures. By the end of the workshop, participants will gain newfound confidence in their ability to write high-quality JavaScript code that stands the test of time.
Points Covered:
1. Introduction to JavaScript Patterns2. Foundational Patterns3. Object Creation Patterns4. Behavioral Patterns5. Architectural Patterns6. Hands-On Exercises and Case Studies
How It Will Help Developers:
- Gain a deep understanding of JavaScript patterns and their applications in real-world scenarios- Learn best practices for organizing code, solving common challenges, and designing scalable architectures- Enhance problem-solving skills and code readability- Improve collaboration and communication within development teams- Accelerate career growth and opportunities for advancement in the software industry
AI for React Developers
React Advanced 2024React Advanced 2024
142 min
AI for React Developers
Featured Workshop
Eve Porcello
Eve Porcello
Knowledge of AI tooling is critical for future-proofing the careers of React developers, and the Vercel suite of AI tools is an approachable on-ramp. In this course, we’ll take a closer look at the Vercel AI SDK and how this can help React developers build streaming interfaces with JavaScript and Next.js. We’ll also incorporate additional 3rd party APIs to build and deploy a music visualization app.
Topics:- Creating a React Project with Next.js- Choosing a LLM- Customizing Streaming Interfaces- Building Routes- Creating and Generating Components - Using Hooks (useChat, useCompletion, useActions, etc)

Check out more articles and videos

We constantly think of articles and videos that might spark Git people interest / skill us up or help building a stellar career

Simplifying Server Components
React Advanced 2023React Advanced 2023
27 min
Simplifying Server Components
Top Content
Watch video: Simplifying Server Components
React server components simplify server-side rendering and provide a mental model of components as pure functions. Using React as a library for server components allows for building a basic RSC server and connecting it to an SSR server. RSC responses are serialized virtual DOM that offload code from the client and handle interactivity. The client manifest maps serialized placeholders to real components on the client, enabling dynamic rendering. Server components combine the best of classic web development and progressive enhancement, offering the advantage of moving logic from the client to the server.
A Guide to React Rendering Behavior
React Advanced 2022React Advanced 2022
25 min
A Guide to React Rendering Behavior
Top Content
This transcription provides a brief guide to React rendering behavior. It explains the process of rendering, comparing new and old elements, and the importance of pure rendering without side effects. It also covers topics such as batching and double rendering, optimizing rendering and using context and Redux in React. Overall, it offers valuable insights for developers looking to understand and optimize React rendering.
Don't Solve Problems, Eliminate Them
React Advanced 2021React Advanced 2021
39 min
Don't Solve Problems, Eliminate Them
Top Content
Kent C. Dodds discusses the concept of problem elimination rather than just problem-solving. He introduces the idea of a problem tree and the importance of avoiding creating solutions prematurely. Kent uses examples like Tesla's electric engine and Remix framework to illustrate the benefits of problem elimination. He emphasizes the value of trade-offs and taking the easier path, as well as the need to constantly re-evaluate and change approaches to eliminate problems.
Using useEffect Effectively
React Advanced 2022React Advanced 2022
30 min
Using useEffect Effectively
Top Content
Today's Talk explores the use of the useEffect hook in React development, covering topics such as fetching data, handling race conditions and cleanup, and optimizing performance. It also discusses the correct use of useEffect in React 18, the distinction between Activity Effects and Action Effects, and the potential misuse of useEffect. The Talk highlights the benefits of using useQuery or SWR for data fetching, the problems with using useEffect for initializing global singletons, and the use of state machines for handling effects. The speaker also recommends exploring the beta React docs and using tools like the stately.ai editor for visualizing state machines.
Speeding Up Your React App With Less JavaScript
React Summit 2023React Summit 2023
32 min
Speeding Up Your React App With Less JavaScript
Top Content
Watch video: Speeding Up Your React App With Less JavaScript
Mishko, the creator of Angular and AngularJS, discusses the challenges of website performance and JavaScript hydration. He explains the differences between client-side and server-side rendering and introduces Quik as a solution for efficient component hydration. Mishko demonstrates examples of state management and intercommunication using Quik. He highlights the performance benefits of using Quik with React and emphasizes the importance of reducing JavaScript size for better performance. Finally, he mentions the use of QUIC in both MPA and SPA applications for improved startup performance.
Routing in React 18 and Beyond
React Summit 2022React Summit 2022
20 min
Routing in React 18 and Beyond
Top Content
Routing in React 18 brings a native app-like user experience and allows applications to transition between different environments. React Router and Next.js have different approaches to routing, with React Router using component-based routing and Next.js using file system-based routing. React server components provide the primitives to address the disadvantages of multipage applications while maintaining the same user experience. Improving navigation and routing in React involves including loading UI, pre-rendering parts of the screen, and using server components for more performant experiences. Next.js and Remix are moving towards a converging solution by combining component-based routing with file system routing.