Static generation
When you mark a page as static the file-system based router will add the page as an export to @lazarv/react-server
's exports.
To mark a page as static, create a file with the matching path for the page with the .static.{js,mjs,ts,mts,json}
extension and export default an array or a function returning an array of possible parameters for that route. The function can also be an async function.
For pages without any parameters, export default true
.
users.static.tsexport default true;
The smallest possible way to mark a page as static is by creating a .static.json
file defining true
.
users.static.jsontrue
Warning: you can't use
true
as the value for routes with parameters. You need to define an array of possible parameters or a function returning an array of possible parameters. If you usetrue
for a route with parameters, the build will fail.
For dynamic routes, if you have a page at /users/:id
you can create a file at /users/[id].static.ts
with the following content:
users/[id].static.tsexport default [{ id: 1 }, { id: 2 }, { id: 3 }];
You can either export an array of route parameters or an async function returning an array of route parameters.
users/[id].static.tsexport default async () => [{ id: 1 }, { id: 2 }, { id: 3 }];
Your function will be executed at build time and the result will be used to generate the static pages.
You can use static JSON data for your static pages by creating a file with the .static.json
extension.
For example, if you have a page at /users/:id
you can create a file at /users/[id].static.json
with the following content:
users/[id].static.json[{ "id": 1 }, { "id": 2 }, { "id": 3 }]
Note: we define static routes independently from the page component to separate the concerns of routing and page rendering. This way router doesn't need to import the code defining your page component during build time, which can be useful if you have a large dependency tree for your page component or your code has side-effects.
You can override all static paths by defining an export()
function in your @lazarv/react-server
configuration file. This function will be called with an array of all static paths and you can return a new array of paths to override the default static paths. In this example, we remove the /en
prefix from all static paths.
react-server.config.mjsexport default {
export(paths) {
return paths.map(({ path }) => ({
path: path.replace(/^\/en/, ""),
}));
},
};
You can also use this function to add new static paths or remove some paths.
react-server.config.mjsexport default {
export(paths) {
return [
...paths,
{ path: "/new-page" },
];
},
};
react-server.config.mjsexport default {
export(paths) {
return paths.filter(({ path }) => path !== "/en");
},
};
You can also export API routes as static routes. To do this, you can define your static path as an object with the path
, filename
, method
and headers
properties, where path
is the route path, filename
is the filename for the static file, method
is the HTTP method for the request and headers
is an object with the headers for the request. method
and headers
are optional.
react-server.config.mjsexport default {
export() {
return [
{
path: "/sitemap.xml",
filename: "sitemap.xml",
method: "GET",
headers: {
accept: "application/xml",
},
},
];
},
}
You can also export micro-frontend routes as static. To do this, you can define your static path as an object with the path
and remote
properties, where path
is the route path and remote
is a flag to indicate that the route is a micro-frontend route and the remote response payload needs to be generated at build time. By using static export for micro-frontends, you can improve the performance of your application by pre-rendering the micro-frontend content at build time.
react-server.config.mjsexport default {
export() {
return [
{
path: "/",
remote: true,
}
];
},
};
You can also export outlets as static. To do this, you can define your static path as an object with the path
and outlet
properties, where path
is the route path and outlet
is the name of the outlet. By using static export for outlets, you can improve the performance of your application by pre-rendering the outlet content at build time. Exported outlets will be rendered as RSC components. Client-side navigation to an exported outlet will use the static outlet content instead of making a request to the server.
react-server.config.mjsexport default {
export() {
return [{ path: "/photos/1", outlet: "modal" }];
},
};
You can disable static export for RSC routes by setting the rsc
property to false
. This is useful if you have a page that is an RSC route but you don't want to pre-render it at build time or you don't plan to use the RSC payload for that route. This will prevent the RSC payload from being generated at build time and the route will be rendered only as a regular HTML page to reduce the deployment size.
react-server.config.mjsexport default {
export() {
return [{ path: "/photos/1", rsc: false }];
},
};