发布于2021-03-07 22:19 阅读(1230) 评论(0) 点赞(13) 收藏(5)
主应用:
main.ts
- import { createApp } from 'vue'
- import App from './App.vue'
- import router from './router'
- import store from './store'
-
- createApp(App).use(store).use(router).mount('#app')
-
- import { registerMicroApps, start } from 'qiankun';
-
- // 注册子应用
- registerMicroApps([
- {
- name: 'child1',
- entry: '//localhost:8081',
- container: '#yourContainer',
- activeRule: '/child/child1', // 子应用触发规则(路径)
- },
- ]);
- // 开启服务
- start()
app.vue
- <template>
- <div id="nav">
- 主应用
- <!-- 子应用容器 -->
- <div id="yourContainer" style="width: 100%;border: 1px solid #ccc;"></div>
- <!-- 路由跳转 -->
- <router-link to="/">Home</router-link>
- <router-link to="/about">About</router-link>
- <!-- 子应用路由跳转 -->
- <router-link to="/child/child1">child/child1</router-link>
- </div>
- <router-view/>
- </template>
router index.ts
- import { createRouter, createWebHistory, createWebHashHistory, RouteRecordRaw } from 'vue-router'
- import Home from '../views/Home.vue'
-
- const routes: Array<RouteRecordRaw> = [
- {
- path: '/',
- name: 'Home',
- component: Home
- },
- {
- path: '/about',
- name: 'About',
- // route level code-splitting
- // this generates a separate chunk (about.[hash].js) for this route
- // which is lazy-loaded when the route is visited.
- component: () => import(/* webpackChunkName: "about" */ '../views/About.vue')
- }
- ]
-
- console.log(process.env.BASE_URL)
- const router = createRouter({
- // history: createWebHashHistory(),
- history: createWebHistory(process.env.BASE_URL),
- routes
- })
-
- export default router
子应用:
main.ts
- import { createApp } from 'vue'
- import App from './App.vue'
- import router from './router'
- import store from './store'
-
- const temp: any = window;
- const isQiankun = temp.__POWERED_BY_QIANKUN__
-
- export async function bootstrap() {
- console.log('react app bootstraped');
- }
-
- /**
- * 应用每次进入都会调用 mount 方法,通常我们在这里触发应用的渲染方法
- */
- function render() {
- createApp(App).use(store).use(router).mount('#child1')
- }
- export async function mount(props: any) {
- console.log(props)
- render()
- }
- // createApp(App).use(store).use(router).mount('#child1')
- /**
- * 应用每次 切出/卸载 会调用的方法,通常在这里我们会卸载微应用的应用实例
- */
- export async function unmount(props: any) {
- console.log(props)
- }
-
- /**
- * 可选生命周期钩子,仅使用 loadMicroApp 方式加载微应用时生效
- */
- export async function update(props: any) {
- console.log('update props', props);
- }
-
- isQiankun || render();
router index.ts
- import { createRouter, createWebHistory, createWebHashHistory, RouteRecordRaw } from 'vue-router'
- import Home from '../views/Home.vue'
-
- const routes: Array<RouteRecordRaw> = [
- {
- path: '/',
- name: 'Home',
- component: Home
- },
- {
- path: '/about',
- name: 'About',
- // route level code-splitting
- // this generates a separate chunk (about.[hash].js) for this route
- // which is lazy-loaded when the route is visited.
- component: () => import(/* webpackChunkName: "about" */ '../views/About.vue')
- }
- ]
-
- const router = createRouter({
- history: createWebHistory('/child/child1'),
- // history: createWebHistory(process.env.BASE_URL),
- // history: createWebHashHistory(),
- routes
- })
-
- export default router
vue.config.js
- const { name } = require('./package');
-
- const port = 8081; // dev port
- const dev = process.env.NODE_ENV === 'development'
- module.exports = {
- publicPath: dev ? `//localhost:${port}` : '/',
- devServer: {
- port,
- headers: {
- 'Access-Control-Allow-Origin': '*',
- },
- },
- // 自定义webpack配置
- configureWebpack: {
- output: {
- // 把子应用打包成 umd 库格式
- library: `${name}-[name]`,
- libraryTarget: 'umd',
- jsonpFunction: `webpackJsonp_${name}`,
- },
- },
- };
index.html
- <!DOCTYPE html>
- <html lang="">
- <head>
- <meta charset="utf-8">
- <meta http-equiv="X-UA-Compatible" content="IE=edge">
- <meta name="viewport" content="width=device-width,initial-scale=1.0">
- <link rel="icon" href="<%= BASE_URL %>favicon.ico">
- <title><%= htmlWebpackPlugin.options.title %></title>
- </head>
- <body>
- <noscript>
- <strong>We're sorry but <%= htmlWebpackPlugin.options.title %> doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>
- </noscript>
- <!-- id不能与主应用重复 -->
- <div id="child1"></div>
- <!-- built files will be auto injected -->
- </body>
- </html>
原文链接:https://blog.csdn.net/qq_39785489/article/details/114384999
作者:加油打工人
链接:http://www.qianduanheidong.com/blog/article/33576/7deaffb84ff2e255184a/
来源:前端黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 前端黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-3
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!