Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/FEMessage/nuxt-micro-frontend
🎳Nuxt module for micro-frontend solution
https://github.com/FEMessage/nuxt-micro-frontend
Last synced: 4 months ago
JSON representation
🎳Nuxt module for micro-frontend solution
- Host: GitHub
- URL: https://github.com/FEMessage/nuxt-micro-frontend
- Owner: FEMessage
- License: mit
- Created: 2020-02-19T09:39:37.000Z (about 5 years ago)
- Default Branch: dev
- Last Pushed: 2021-10-26T14:40:31.000Z (over 3 years ago)
- Last Synced: 2024-10-06T11:04:45.895Z (5 months ago)
- Language: JavaScript
- Homepage: https://deep-han.github.io/qiankun
- Size: 544 KB
- Stars: 128
- Watchers: 11
- Forks: 27
- Open Issues: 13
-
Metadata Files:
- Readme: README-zh.md
- License: LICENSE
Awesome Lists containing this project
README
# Nuxt-Micro-Front-End
[data:image/s3,"s3://crabby-images/f1f89/f1f897062ac638f8eb19818d0675c73f267db0fc" alt="Build Status"](https://travis-ci.com/FEMessage/nuxt-micro-frontend)
[data:image/s3,"s3://crabby-images/a597e/a597e507d036faf9ac1c08745108b490fe86458c" alt="NPM Download"](https://www.npmjs.com/package/@femessage/nuxt-micro-frontend)
[data:image/s3,"s3://crabby-images/a8c85/a8c8542569e5530a8d2081b660a8efd1b5e453c5" alt="NPM Version"](https://www.npmjs.com/package/@femessage/nuxt-micro-frontend)
[data:image/s3,"s3://crabby-images/b3255/b3255251a7ee591e106c2348ed88fd3372787106" alt="NPM License"](https://github.com/FEMessage/nuxt-micro-frontend/blob/master/LICENSE)
[data:image/s3,"s3://crabby-images/eb397/eb397a029e6c13badccbdfa959963ed40767b2e7" alt="PRs Welcome"](https://github.com/FEMessage/nuxt-micro-frontend/pulls)
[data:image/s3,"s3://crabby-images/aa929/aa929e88533f74f07ed318ebdac11663b249a3d5" alt="Automated Release Notes by gren"](https://github-tools.github.io/github-release-notes/)使用 Nuxt 实践微前端架构,现在已经支持 [qiankun](https://qiankun.umijs.org/)
[English](./README.md)
[📖 **发布日志**](./CHANGELOG.md)
## 安装
1. 添加 `@femessage/nuxt-micro-frontend` 依赖到你的项目中
```bash
yarn add @femessage/nuxt-micro-frontend -D# or npm install @femessage/nuxt-micro-frontend
```2. 添加 `@femessage/nuxt-micro-frontend` 到 `nuxt.config.js` 的 `modules` 属性中
```js
{
modules: [
// 一般使用
'@femessage/nuxt-micro-frontend',// 带上模块参数
['@femessage/nuxt-micro-frontend', { /* module options */ }]
]
}
```## 模块参数
[文档](https://github.com/FEMessage/micro-nuxt/blob/master/lib/module.js)
> 推荐使用 `build.devMiddleware.headers` 属性来设置开发环境资源 http header, 可以查看 Nuxt API: The build Property > [devMiddleware](https://nuxtjs.org/api/configuration-build#devmiddleware)
**path**: 微前端生命周期函数定义文件,相对 rootDir 的路径
**force**: 强制使用模块功能,忽略 Nuxt 版本校验
**unique**: 由于 qiankun 需要一个唯一的包名区分多个子应用,如果懒得修改可以将这个属性设置为 `true`,这样会生成一个唯一的包名
**output**: 由于接入不同的生态体系,需要不同的打包格式,这里可以根据 [webpack output](https://webpack.js.org/configuration/output/) 提供的选项进行注入
## 支持的微前端框架
- [x] [qiankun](https://github.com/umijs/qiankun)
- [x] [single-SPA](https://github.com/single-spa/single-spa) demo 在 examples/single-spa-demo 下## 微前端生命周期函数例子
[Qiankun](https://github.com/FEMessage/micro-nuxt/blob/master/examples/normal/mfe.js)- 增加了 `mounted` 和 `beforeUnmount` 两个钩子方便操作 vue 实例
## 开发
1. 克隆此仓库
2. 安装依赖 `yarn install` 或者 `npm install`
3. 运行 `cd examples/normal && npm run dev` 启动开发服务## License
[MIT License](./LICENSE)
Copyright (c) FEMessage