routerEdit this page

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.ts
export default true;

The smallest possible way to mark a page as static is by creating a .static.json file defining true.

users.static.json
true

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 use true 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.ts
export 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.ts
export 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.mjs
export 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.mjs
export default { export(paths) { return [ ...paths, { path: "/new-page" }, ]; }, };
react-server.config.mjs
export 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.mjs
export 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.mjs
export 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.mjs
export 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.mjs
export default { export() { return [{ path: "/photos/1", rsc: false }]; }, };