Giter Site home page Giter Site logo

microfrontend-module-federation's Introduction

Criando Micro-Front-Ends com Webpack5 Module Federation

Criar 3 micro-front-ends com compartilhamento de código de forma bidirecional, a ideia é de no final da dessa aula ter um modelo de e-commerce bem simples onde teremos a mesma experiência sendo criada e compartilhada entre os nossos MFE's, compartilhando código em tempo de execução sem perda de desempenho.

Aplicação Final 🎬

Observe aqui que estamos navegando em diferentes servidores, mas a experiência final.

Instale as dependências do diretório principal do projeto:

|⚠️ usaremos yarn para gerenciar nossos pacotes

yarn install

em seguida, entre no diretório dos nossos MFE's

cd  shared-routing

Instale as dependencias

yarn install

Inicie o servidor de desenvolvimento:

yarn  start

Com isso, você terá os aplicativos em execução em:

Abra uma dessas portas no navegador de sua escolha e você estará pronto para integrar com o aplicativo inicial 🚀.

Estrutura do Projeto 🏗

Conforme descrito, criaremos uma estrutura MFE com hosts host bidirecionais podemos ver aqui o gráfico de como nossos MFE's vão ser divididos

Na pasta Container/shared-routing, temos os nossos MFE's:

  • Shell: MFE Onde vamos criar o nosso application shell
  • ProductList /: MFE responsavel pela listagem de produtos
  • ProductDetails /: MFE responsavel pelo detalhamento de produtos
├── ProductDetails
│   ├── package.json
│   ├── public
│   ├── src
│   └── webpack.config.js
├── ProductList
│   ├── package.json
│   ├── public
│   ├── src
│   └── webpack.config.js
├── Shell
│   ├── package.json
│   ├── public
│   ├── src
│   └── webpack.config.js
├── package.json
└── yarn.lock

Ferramentas Utilizadas 🧰

  • React como uma linguagem de IU
  • Webpack5 como module bundler
  • Prettier como formatador de código
  • Lerna para gerenciar o monorepo
  • TailwindCss UI como nosso kit de ferramentas de design

microfrontend-module-federation's People

Contributors

vyseclown avatar

Watchers

James Cloos avatar  avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.