Common examples of when you may want to use this type of pre-rendering are: displaying a list of articles on a blog homepage, displaying a list of products on a homepage, or displaying a list of topics on a documentation page.
All you have to do is define the async function getStaticProps fetch your data within the function and return an object with the necessary props. The props will then be availabe for use in your component
- delete API folder from Pages
- delete home.module.css from styles
- changed index.js file content into simple component that returns a plain h1 tag.
Using the users data from JSONPlaceholder for test APIs
-
create a new file in Pages folder named "users.js"
- within the file, defined and exported UserList compontent
-
in Next, when you export a page component, you can also export an async function called "getStaticProps"
- This function will run at build time in production. Inside the function, you can fetch external data and send it as "props" to the page.
-
go to users.js and export the getStaticProps async function
-
pass in the JSONPaceholder/users URL as an argument.
-
once you have the reponse, you convert it into JSON and log it to the console
-
then, you need to pass the data to the component above
-
this is accomplished via a return object
-
the object contains another object named 'props' that can contain any key value pairs, which will be automatically injected as props into the component.
- in our case, we set one property named 'users' which is set to 'data'
- when we return this, the userlist component will receive the props at build time
- so, you pass in 'props' as an arugment. you could also destructure the users property.
-
To render
- wrap the UserList return in a React fragment
- map over the list of user
- for each user, we're returning a div tag where the key tag is set to user.id
- then, we're rendering user.name and user.email
- you could map more, but we're only using name and email in this example
- getStaticProps runs only on the server side
- the fucntion will never fun client-side
- the code you write inside getStaticProp won't even be included in the JS bundle that is sent to the browser
- You can write server-side code directly in getSaticProps
- Accessing the file system using the fs moduleor querying a database can be done inside getStaticProps
- getStaticProps is allowed only in page and cannot be run from a regular component file
- It is used only for pre-rendering and not client-side data fetching
- getStaticProps should return an object and object should contain a props key which is an object
- getStaticProps will run at build time
- During development, getStaticProps runs on every request
This is a Next.js project bootstrapped with create-next-app
.
First, run the development server:
npm run dev
# or
yarn dev
Open http://localhost:3000 with your browser to see the result.
You can start editing the page by modifying pages/index.js
. The page auto-updates as you edit the file.
API routes can be accessed on http://localhost:3000/api/hello. This endpoint can be edited in pages/api/hello.js
.
The pages/api
directory is mapped to /api/*
. Files in this directory are treated as API routes instead of React pages.
To learn more about Next.js, take a look at the following resources:
- Next.js Documentation - learn about Next.js features and API.
- Learn Next.js - an interactive Next.js tutorial.
You can check out the Next.js GitHub repository - your feedback and contributions are welcome!
The easiest way to deploy your Next.js app is to use the Vercel Platform from the creators of Next.js.
Check out our Next.js deployment documentation for more details.