This repository demonstrates a microfrontend architecture using React, Vite, and Module Federation. The project consists of a host application and multiple microfrontends that can be developed, deployed, and scaled independently.
The architecture consists of:
- Host Application: The container application that integrates microfrontends
- Microfrontend 1 (MFE1): A standalone application exposed to the host
- Microfrontend 2 (MFE2): Another standalone application exposed to the host
Each application is a complete React application with its own build process, dependencies, and deployment pipeline. They communicate through Module Federation, allowing them to share components, state, and dependencies.
- Independent Development: Each microfrontend can be developed independently
- Shared Dependencies: Common libraries like React are shared to avoid duplication
- State Management: Centralized state management using Zustand
- Environment Configuration: Environment-specific configuration for different deployment targets
- TypeScript Support: Full TypeScript support across all applications
- Node.js (v18+)
- Yarn or npm
- Basic knowledge of React, TypeScript, and Vite
react-microfrontend/
├── host/                 # Host application
│   ├── src/              # Source code
│   │   ├── environments/ # Environment configurations
│   │   ├── store/        # Shared state management
│   │   └── ...
│   ├── package.json      # Dependencies and scripts
│   └── vite.config.ts    # Vite and Module Federation configuration
├── mfe1/                 # Microfrontend 1
│   ├── src/              # Source code
│   │   ├── environments/ # Environment configurations
│   │   └── ...
│   ├── package.json      # Dependencies and scripts
│   └── vite.config.ts    # Vite and Module Federation configuration
└── mfe2/                 # Microfrontend 2
    ├── src/              # Source code
    │   ├── environments/ # Environment configurations
    │   └── ...
    ├── package.json      # Dependencies and scripts
    └── vite.config.ts    # Vite and Module Federation configuration
mkdir react-microfrontend
cd react-microfrontend
mkdir host mfe1 mfe2cd host
yarn create vite . --template react-tsInstall additional dependencies:
yarn add zustand
yarn add -D @originjs/vite-plugin-federation concurrently nodemoncd ../mfe1
yarn create vite . --template react-ts
yarn add -D @originjs/vite-plugin-federation concurrently nodemoncd ../mfe2
yarn create vite . --template react-ts
yarn add -D @originjs/vite-plugin-federation concurrently nodemon 
- Independent Deployment: Each microfrontend can be deployed independently
- Environment Configuration: Use different environment files for different deployment targets
- URL Configuration: Update the remote URLs in environment files for production deployments
- Versioning: Consider versioning your microfrontends for better stability
- Routing: Implement routing within microfrontends using React Router
- Authentication: Share authentication state between microfrontends
- Error Boundaries: Implement error boundaries to prevent one microfrontend from crashing others
- Performance Optimization: Optimize bundle sizes and loading strategies
- Testing: Implement unit and integration tests for microfrontends
- Module Federation Issues: Ensure shared dependencies have compatible versions
- CORS Issues: Make sure CORS is properly configured in development and production
- Build Issues: Check that all applications are built with compatible settings
This microfrontend architecture provides a scalable approach to building complex React applications. By separating concerns into independent applications, teams can work more efficiently and deploy more frequently, while still providing a cohesive user experience.