前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >vue3微前端架构——基于蚂蚁qiankun框架

vue3微前端架构——基于蚂蚁qiankun框架

作者头像
liulun
发布2020-12-08 10:34:56
3.5K0
发布2020-12-08 10:34:56
举报
文章被收录于专栏:liulunliulun

楔子

首先,目前qiankun框架尚不支持vite,

微应用不能使用vite创建,

即使只是生产环境加的载微应用也不行,

因为vite打包代码时,内部的esbuild会tree shake掉与qiankun相关的生命周期钩子,

主应用没影响,使用什么创建项目都无所谓

主应用

没啥特殊的,随便一个组件里留个容器div

代码语言:javascript
复制
<div id="container"></div>

在一个方法内加载微应用

代码语言:javascript
复制
import { loadMicroApp } from 'qiankun';
export default {
  setup(){
    let create = ()=>{
      loadMicroApp({ 
          name: 'vue3', 
          entry: 'http://localhost:7105/',
          container: '#container', 
        });
    }
    return {create};
  }
}

通过路由注册微应用的方式,请自己看文档

微应用

配置文件:vue.config.js

代码语言:javascript
复制
const path = require('path');
const { name } = require('./package');

function resolve(dir) {
  return path.join(__dirname, dir);
}

const port = 7105;

module.exports = {
  outputDir: 'dist',
  assetsDir: 'static',
  filenameHashing: true,
  devServer: {
    hot: true,
    disableHostCheck: true,
    port,
    overlay: {
      warnings: false,
      errors: true,
    },
    headers: {
      'Access-Control-Allow-Origin': '*',
    },
  },
  // 自定义webpack配置
  configureWebpack: {
    resolve: {
      alias: {
        '@': resolve('src'),
      },
    },
    output: {
      // 把子应用打包成 umd 库格式
      library: `${name}-[name]`,
      libraryTarget: 'umd',
      jsonpFunction: `webpackJsonp_${name}`,
    },
  },
};

router.js

代码语言:javascript
复制
import HelloWorld from "./components/HelloWorld.vue";
import HelloWorld2 from "./components/HelloWorld2.vue";
import { createRouter, createWebHistory } from "vue-router";
const routes = [
  { path: "/", component: HelloWorld },
  { path: "/about", component: HelloWorld2 },
];
const router = createRouter({
  history: createWebHistory(window.__POWERED_BY_QIANKUN__ ? "/vue3" : "/"),
  routes,
});
export default router;

main.js

这里有好多钩子,是给主应用用的

代码语言:javascript
复制
if (window.__POWERED_BY_QIANKUN__) {
  // eslint-disable-next-line no-undef
  __webpack_public_path__ = window.__INJECTED_PUBLIC_PATH_BY_QIANKUN__;
}
import { createApp } from "vue";
import App from "./App.vue";
import router from "./router";
let instance = null;

function render(props = {}) {
  const { container } = props;

  instance = createApp(App);
  instance.use(router);
  instance.mount(container ? container.querySelector("#app") : "#app");
}

if (!window.__POWERED_BY_QIANKUN__) {
  render();
}

export async function bootstrap() {
  console.log("%c ", "color: green;", "vue3.0 app bootstraped");
}

export async function mount(props) {
  render(props);
  instance.config.globalProperties.$onGlobalStateChange =
    props.onGlobalStateChange;
  instance.config.globalProperties.$setGlobalState = props.setGlobalState;
}

export async function unmount() {
  instance.unmount();
  instance._container.innerHTML = "";
  instance = null;
}

app.vue

代码语言:javascript
复制
<template>
<button @click="go('/')">home</button>
<button @click="go('/about')">sub</button>
  <router-view></router-view>
</template>

<script>
import router from "./router"
export default {
  setup(){
    let go = (p)=>{
      router.push(p)
    }
    return {go}
  }
}
</script>
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2020-12-05 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 楔子
  • 主应用
  • 微应用
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档