基座配置
1.添加一个跳转到子应用的 router-link 的标签,也可以使用 qiankun 跳转方法去跳转页面
2.需要给你的子项目添加挂载的容器, 比如我把 vue 子项目 挂载到
3.给基座(父级项目)安装 qiankun 依赖:yarn add qiankun -S
4.在 main.js 中引入 qiankun: import { registerMicroApps, start } from “qiankun”;
5.定义 子应用 数组 数据
import { registerMicroApps, start } from "qiankun";
const apps = [
{
name: "vueApp",
entry: "//localhost:10000",
container: "#vue",
activeRule: "/vue",
props: {
a: 1,
},
},
{
name: "reactApp",
entry: "//localhost:20000",
container: "#react",
activeRule: "/react",
},
];
registerMicroApps(apps);
start();
Vue 项目配置
1.router 文件修改 base: ‘/vue’
2. 在 main.js 中 必须导出三个方法
let instance = null;
function render(props) {
instance = new Vue({
router,
render: (h) => h(App),
}).$mount("#app");
}
if (!window.__POWERED_BY_QIANKUN__) {
render();
}
if (window.__POWERED_BY_QIANKUN__) {
__webpack_public_path__ = window.__INJECTED_PUBLIC_PATH_BY_QIANKUN__;
}
export async function bootstrap(props) {
console.log(props.a);
}
export async function mount(props) {
render(props);
}
export async function unmount(props) {
instance.$destroy();
}
3.配置 vue.config.js 使其子项目导出一个 lib 库
module.exports = {
configureWebpack: {
output: {
library: "vueApp",
libraryTarget: "umd",
},
devServer: {
port: 10000,
headers: {
"Access-Control-Allow-Origin": "*",
},
},
},
};
react 项目配置
1.因为需要写一些 webpack 的配置,所以需要安装一个插件:yarn add react-app-rewired -D
1.1 需要更改一下命令(start\build 都需要改一下):react-app-rewired start、:react-app-rewired build
2. 和 Vue 项目一样,先导出三个方法,如下:
3. 封装一个 render 函数
4. 需要在 unmount 中卸载应用
5. 让本地环境可以正常运行需要添加开发环境的 render 函数的执行
6. 如果子应用和基座项目的访问 ip 不同,qiankun 可以动态的改变子应用的 ip
if (!window.__POWERED_BY_QIANKUN__) {
render();
}
if (window.__POWERED_BY_QIANKUN__) {
__webpack_public_path__ = window.__INJECTED_PUBLIC_PATH_BY_QIANKUN__;
}
function render() {
ReactDOM.render(
<React.StrictMode>
<App />
</React.StrictMode>,
document.getElementById("root")
);
}
export async function bootstrap(props) {
console.log(props.a);
}
export async function mount(props) {
render(props);
}
export async function unmount(props) {
ReactDOM.unmountComponentAtNode(document.getElementById("root"));
}
|