# Prerendering static pages Angular Universal allows you to prerender the pages of your application. Prerendering is the process where a dynamic page is processed at build time generating static HTML. ## How to prerender a page To prerender a static page make sure to add SSR capabilities to your application. For more information see the [universal guide](guide/universal). Once SSR is added, run the following command: npm run prerender ### Build options for prerendering When you add prerendering to your application, the following build options are available: * `browserTarget`: Specify the target to build. * `serverTarget`: Specify the Server target to use for prerendering the application. * `routes`: Define an array of additional routes to prerender. * `guessRoutes`: Whether builder should extract routes and guess which paths to render. Defaults to `true`. * `routesFile`: Specify a file that contains a list of all routes to prerender, separated by newlines. This option is useful if you have a large number of routes. * `numProcesses`: Specify the number of CPUs to be used while running the prerendering command. ### Prerendering dynamic routes You can prerender dynamic routes. An example of a dynamic route is `product/:id`, where `id` is dynamically provided. To prerender dynamic routes, choose one from the following options: * Provide additional routes in the command line * Provide routes using a file * Prerender specific routes #### Provide additional routes in the command line While running the prerender command, you can provide additional routes. For example: ng run <app-name>:prerender --routes /product/1 /product/2 #### Providing additonal routes using a file You can provide routes using a file to generate static pages. This method is useful if you have a large number of routes to generate, such as product details for an e-commerce application, which may come from an external source (Database or CMS). To provide routes using a file, use the `--routes-file` option with the name of a `.txt` file containing the routes. For example, you could generate this file by using a script to extract IDs from a database and save them to a `routes.txt` file: /products/1 /products/555 When your `.txt` file is ready, run the following command to prerender the static files with dynamic values: ng run <app-name>:prerender --routes-file routes.txt #### Prerendering specific routes You can also pass specific routes to the prerender command. If you choose this option, make sure to disable the `guessRoutes` option. ng run <app-name>:prerender --no-guess-routes --routes /product/1 /product/1