Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jd-opensource/micro-app
A simple, efficient and powerful micro front-end framework. 一款简约、高效、功能强大的微前端框架
https://github.com/jd-opensource/micro-app
javascript micro-frontend microapp webcomponents
Last synced: 4 days ago
JSON representation
A simple, efficient and powerful micro front-end framework. 一款简约、高效、功能强大的微前端框架
- Host: GitHub
- URL: https://github.com/jd-opensource/micro-app
- Owner: jd-opensource
- License: mit
- Created: 2021-06-24T12:26:23.000Z (over 3 years ago)
- Default Branch: master
- Last Pushed: 2025-01-22T13:23:21.000Z (6 days ago)
- Last Synced: 2025-01-22T14:26:25.601Z (6 days ago)
- Topics: javascript, micro-frontend, microapp, webcomponents
- Language: CSS
- Homepage: https://jd-opensource.github.io/micro-app/
- Size: 9.37 MB
- Stars: 5,749
- Watchers: 49
- Forks: 584
- Open Issues: 244
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- jimsghstars - jd-opensource/micro-app - A simple, efficient and powerful micro front-end framework. 一款简约、高效、功能强大的微前端框架 (CSS)
README
English|[简体中文](./README.zh-cn.md)|[Documentation](https://jd-opensource.github.io/micro-app/)|[Discussions](https://github.com/jd-opensource/micro-app/discussions)|[WeChat](./Contact.md)
# 📖Introduction
micro-app is a micro front-end framework launched by JD Retail. It renders based on webcomponent-like and realizes the micro front-end from component thinking, it aiming to reduce the difficulty of getting started and improve work efficiency.It is the lowest cost framework for accessing micro front-end, and provides a series of perfect functions such as JS sandbox, style isolation, element isolation, preloading, resource address completion, plugin system, data communication and so on.
micro-app has no restrictions on the front-end framework, and any framework can be used as a base application to embed any type of micro application of the framework.
# How to use
## Base application
**1、Install**
```bash
yarn add @micro-zoe/micro-app
```**2、import at the entrance**
```js
// main.js
import microApp from '@micro-zoe/micro-app'microApp.start()
```**3、Use components in page**
```html
```
## Sub application
**Set cross-domain support in the headers of webpack-dev-server**
```js
devServer: {
headers: {
'Access-Control-Allow-Origin': '*',
},
},
```The above micro front-end rendering is completed, and the effect is as follows:
![image](https://img10.360buyimg.com/imagetools/jfs/t1/188373/14/17696/41854/6111f4a0E532736ba/4b86f4f8e2044519.png)
More detailed configuration can be viewed [Documentation](https://jd-opensource.github.io/micro-app/docs.html#/zh-cn/start).
# 🤝 Contribution
If you're interested in this project, you're welcome to mention pull request, and also welcome your "Star" ^_^### development
1、Clone
```
git clone https://github.com/jd-opensource/micro-app.git
```2、Install dependencies
```
yarn bootstrap
```3、Run project
```
yarn start
```For more commands, see [DEVELOP](https://github.com/jd-opensource/micro-app/blob/master/DEVELOP.md)
# FAQ
What are the advantages of micro-app?
It is easy to use and low invasive. It only needs to change a small amount of code to access the micro front-end, and provides rich functions at the same time.How compatible?
The micro-app relies on two newer APIs, CustomElements and Proxy.For browsers that do not support CustomElements, they can be compatible by introducing polyfills. For details, please refer to: [webcomponents/polyfills](https://github.com/webcomponents/polyfills/tree/master/packages/custom-elements)。
However, Proxy is not compatible for the time being, so the micro-app cannot be run on browsers that do not support Proxy.
Browser compatibility can be viewed: [Can I Use](https://caniuse.com/?search=Proxy)
The general is as follows:
- desktop: Except IE browser, other browsers are basically compatible.
- mobile: ios10+、android5+Must micro applications support cross-domain?
yes!If it is a development environment, you can set headers in webpack-dev-server to support cross-domain.
```js
devServer: {
headers: {
'Access-Control-Allow-Origin': '*',
},
}
```If it is a production environment, you can support cross-domain through [Configuration nginx](https://segmentfault.com/a/1190000012550346).
Does it support vite?
Yes, please see [adapt vite](https://jd-opensource.github.io/micro-app/docs.html#/zh-cn/framework/vite) for details.Does it support ssr?
Yes, please see [nextjs](https://jd-opensource.github.io/micro-app/docs.html#/zh-cn/framework/nextjs), [nuxtjs](https://jd-opensource.github.io/micro-app/docs.html#/zh-cn/framework/nuxtjs) for details.# License
[MIT License](https://github.com/jd-opensource/micro-app/blob/master/LICENSE)