Use Dynamic Imports in Your SharedComponents MicroFrontend App
The SharedComponent in a MicroFrontend plays a crucial role as it manages and provides common or reusable components across different applications. Therefore, having a well-defined strategy for building, exporting, and importing these components is essential. Without proper management, the bundle size can gradually increase over time, leading to performance issues and slower application load times. By optimizing how shared components are handled, you can ensure efficient resource usage and maintain a fast, scalable application.
Let’s say we have an application called AdminApp, and we want to use a shared component named CustomButton. As we know can simply import it using:
data:image/s3,"s3://crabby-images/3d2f6/3d2f65c7274556599d34881088d42fbf0c17ca23" alt=""
The problem is not here, but in the SharedComponents it self, how are we exporting that CustomButton?
data:image/s3,"s3://crabby-images/52143/521439ca21b520c1a55db20b8d416d75f1d1314a" alt=""
It would include the entire code of the component inside the final bundle, and if you export more component like that, this leads to unnecessary bloat and increased load times.
Instead, a better approach is to split the shared components and load them only when required. This way, we optimize performance, reduce the initial bundle size, and ensure that each microfrontend loads only the dependencies it truly needs.
data:image/s3,"s3://crabby-images/ddb2c/ddb2c12672e716a361fcb100eb2ac06a33fe18ac" alt=""
Again and very important: by dynamically loading only the required components, we keep the bundle size optimized, improving application performance load times.
data:image/s3,"s3://crabby-images/07dcf/07dcf587dc7e23aa20361e86c18af89cbd7ea06e" alt=""
In upcoming articles, I will dive deeper into this topic and explore advanced optimization techniques for handling larger components that can be deferred for even greater performance improvements.
Member discussion