Lazy Router
Enhance the performance of your oRPC router with lazy-loaded routers.
Enhance the performance of your oRPC router with lazy-loaded routers. Lazy routers in oRPC allow you to defer the loading of specific router modules until they're actually needed. This can improve startup times and optimize resource usage, especially for large applications.
Overview
Lazy routers make your application modular and efficient without sacrificing ease of use. Here's how you can set up and use them:
Key Points:
-
Export Requirement: The
examples/server.ts
file must export a router as the default export. Example: -
Seamless Functionality: Once the lazy router is loaded, it behaves exactly like a standard router. You don't need to configure anything extra or worry about limitations.
-
OpenAPI Compatibility (Optional): Although not required, using the
prefix
method when defining a lazy router is highly recommended for OpenAPI integration.Note: Contract-first approach is optimized by default, so you don't need to use
prefix
when implementing.Adding a prefix helps oRPC dynamically load the router only when it's needed, improving efficiency and alignment with OpenAPI specifications. While optional, incorporating prefixes will greatly benefit your application by streamlining routing behavior.
By using lazy routers, you can keep your application modular and efficient while maintaining the same user-friendly API you're used to.