# emp
**Repository Path**: micro-front-end/emp
## Basic Information
- **Project Name**: emp
- **Description**: No description available
- **Primary Language**: Unknown
- **License**: BSD-3-Clause
- **Default Branch**: master
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 3
- **Forks**: 1
- **Created**: 2021-02-19
- **Last Updated**: 2022-09-12
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
# EMP - Micro Frontends solution
> Base on Webpack 5 & Module Federation
English | [简体中文](./README-zh_CN.md) | [Discussions](https://github.com/efoxTeam/emp/discussions)
An implementation of [Micro Frontends](https://micro-frontends.org/), based on [Webpack5 Module Federation](https://webpack.js.org/concepts/module-federation/), but made it production-ready.
## 👨🏻💻 Table of contents
* [Projects](https://github.com/efoxTeam/emp#-projects)
* [Documentation](https://github.com/efoxTeam/emp#-documentation)
* [Quick Overview](https://github.com/efoxTeam/emp#-quick-overview)
* [Framework Config Plugins](https://github.com/efoxTeam/emp#-framework-config-plugins)
* [EMP multi-frame intermodulation conversion plug-in](https://github.com/efoxTeam/emp#-emp-multi-frame-intermodulation-conversion-plug-in)
* [Demos](https://github.com/efoxTeam/emp#-demos)
* [Use multiple frameworks in EMP Application](https://github.com/efoxTeam/emp#-use-multiple-frameworks-in-emp-application)
* [Community](https://github.com/efoxTeam/emp#-community)
## 📦 Projects
|Project|NPM|Info|
|---|---|---|
|[@jkyu/emp-cli](packages/emp-cli)|[](https://www.npmjs.com/package/@jkyu/emp-cli)|CLI|
|[@jkyu/emp-tsconfig](packages/emp-tsconfig)|[](https://www.npmjs.com/package/@jkyu/emp-tsconfig)|Typescript Config|
|[@jkyu/emp-tune-dts-plugin](packages/emp-tune-dts-plugin)|[](https://www.npmjs.com/package/@jkyu/emp-tune-dts-plugin)| Webpack Plugin for Module Federation Project in Typescript|
|[@jkyu/eslint-config-react-prittier-ts](packages/eslint-config-react-prittier-ts)|[](https://www.npmjs.com/package/@jkyu/eslint-config-react-prittier-ts)|ESLint Config|
|[@jkyu/emp-sync-vscode-plugin](https://github.com/efoxTeam/emp-sync-vscode-plugin)|[](https://marketplace.visualstudio.com/items?itemName=Benny.emp-sync-base)|EMP Type Synchronize VSCode Plugin|
## 📖 Documentation
[https://github.com/efoxTeam/emp/wiki](https://github.com/efoxTeam/emp/wiki)
## 💿 Quick Overview
```sh
npx @jkyu/emp-cli init
cd my-emp && yarn && yarn dev
```
+ If you've previously installed `@jkyu/emp-cli`,globally via `npm install -g @jkyu/emp-cli` or `yarn global add @jkyu/emp-cli `.
+ we recommend you uninstall the package using `npm uninstall -g @jkyu/emp-cli` or `yarn global remove @jkyu/emp-cli` to ensure that npx always uses the latest version.
+ run `cd my-emp && yarn && yarn dev`,the project will automatically open in the browser.
+ If you want to know more about the use of `@jkyu/emp-cli`, go to [emp-cli](https://github.com/efoxTeam/emp/tree/main/packages/emp-cli).
## ✨ Framework Config Plugins
|Framework|NPM|demo|project|install|
|---|---|---|---|---|
|react|[](https://www.npmjs.com/package/@jkyu/emp-react)|[demo](projects/react)|[@jkyu/emp-react](packages/emp-frameworks/react)|`yarn add @jkyu/emp-react -D`|
|vue2|[](https://www.npmjs.com/package/@jkyu/emp-vue2)|[demo](projects/vue2)|[@jkyu/emp-vue2](packages/emp-frameworks/vue2)|`yarn add @jkyu/emp-vue2 -D`|
|vue3|[](https://www.npmjs.com/package/@jkyu/emp-vue3)|[demo](projects/vue3-base)|[@jkyu/emp-vue3](packages/emp-frameworks/vue3)|`yarn add @jkyu/emp-vue3 -D`|
|svelte|[](https://www.npmjs.com/package/@jkyu/emp-svetle)|[demo](projects/svelte)|[@jkyu/emp-svelte](packages/emp-frameworks/svelte)|`yarn add @jkyu/emp-svetle -D`|
|preact|[](https://www.npmjs.com/package/@jkyu/emp-preact)|[demo](projects/preact)|[@jkyu/emp-preact](packages/emp-frameworks/preact)|`yarn add @jkyu/emp-preact -D`|
|cocos2d|[](https://www.npmjs.com/package/@jkyu/emp-preact)|[demo](projects/cocos2d)|[@jkyu/emp-cocos2d](packages/emp-frameworks/cocos2d)|`yarn add @jkyu/emp-cocos2d -D`|
## ⚡ Compile
|Framework|NPM|demo|install|
|---|---|---|---|
|[emp-swc](https://swc.rs/)|[](https://www.npmjs.com/package/@jkyu/emp-vuett)|[plugin](packages/emp-compile/swc) [react-demo](projects/swc-react-ts)|`yarn add @jkyu/emp-swc`|
## ⚡ EMP multi-frame intermodulation conversion plug-in
|Framework|NPM|demo|install|
|---|---|---|---|
|emp-vue2-in-vue3|[](https://www.npmjs.com/package/@jkyu/emp-vuett)|[demo](projects/vue3-project)|`yarn add @jkyu/emp-vuett`|
## 📦 Demos
|Framework|demo|cli|
|---|---|---|
|
|[react-demo1](projects/demo1) [react-demo2](projects/demo2)|`cd projects && yarn dev`|
|
|[vue3-base](projects/vue3-base) [vue3-project](projects/vue3-project)|`cd projects && yarn dev:vue`|
|
|[vue2-base](projects/vue2-base) [vue2-project](projects/vue2-project)|`cd projects && yarn dev:vue2`|
|
|[antd-base](projects/antd-base) [antd-project](projects/antd-project1)|`cd projects && yarn dev:antd`|
|
|[preact-base](projects/preact-base) [preact-project](projects/preact-project)|`cd projects && yarn dev:preact`|
|
|[cocos2d-base](projects/cocos2d-base) [cocos2d-project](projects/cocos2d-project)|`cd projects && yarn dev:cocos2d`|
|
|[https](projects/https)|`cd projects/https && yarn dev`|
|
|[dynamic-system-host](projects/dynamic-system-host)|`cd projects && yarn dev:dynamichost`|
|
|[dotenv](projects/empty-project/.env.prod)|`cd projects/empty-project && yarn dev`|
## 💪 Use multiple frameworks in EMP Application
|Framework|demo|cli|
|---|---|---|
|
|[React 16](projects/react-diff16) & [React 17](projects/react-diff17)|`cd projects && yarn dev:reactdiff`|
|
|[Vue use React](projects/reactVue-vue) & [React use Vue](projects/reactVue-react)|`cd projects && yarn dev:reactvue`|
|
|[Vue3](projects/vue23-vue2) & [Vue2](projects/vue23-vue3)|`cd projects && yarn dev:vue23`|
## 👬 Community
* WeChat Group:
* WeChat Official Account: Efox
* Juejin:
https://juejin.cn/user/483440843559406/posts
* oschina:
https://my.oschina.net/u/568478