This repository contains the codebase for a microfrontend architecture using Single SPA. The project is divided into separate folders for different microfrontends and a shell application to orchestrate them. Follow the steps below to set up and run the project. In this example we gonna use ReactJs and VueJs for demo purpose but for sure it apply in the same way for other JS frameworks, check the list here: https://single-spa.js.org/docs/ecosystem
Navigate to the footer
folder:
cd footer
npm install
npm start
Navigate to the main
folder:
cd main
npm install
npm run serve
Navigate to the navbar
folder:
cd navbar
npm install
npm start
Navigate to the shell
folder:
cd shell
npm install
Edit the index.ejs
file and double-check the ports for other projects in the systemjs-importmap script. Adjust the URLs as needed:
<script type="systemjs-importmap">
{
"imports": {
"react": "https://cdn.jsdelivr.net/npm/[email protected]/umd/react.production.min.js",
"react-dom": "https://cdn.jsdelivr.net/npm/[email protected]/umd/react-dom.production.min.js",
"@demo/root-config": "//localhost:9000/demo-root-config.js",
"@demo/navbar": "http://localhost:8082/demo-navbar.js",
"@demo/main": "http://localhost:8080/js/app.js",
"@demo/footer": "http://localhost:8081/demo-footer.js"
}
}
</script>
Run the following command to start the shell:
npm start
Navigate to http://localhost:9000/ to access the shell application. Ensure that the devtools
item in the local storage is set to true
to view the results in the root.
Now, you should have a running microfrontend architecture using Single SPA. Each microfrontend can be developed and tested independently, and the shell orchestrates them for a seamless user experience.