iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >微前端qiankun改造实例分析
  • 917
分享到

微前端qiankun改造实例分析

2023-07-02 10:07:46 917人浏览 八月长安
摘要

本文小编为大家详细介绍“微前端qiankun改造实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“微前端qiankun改造实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。改造过程首先我先用Vue2-a

本文小编为大家详细介绍“微前端qiankun改造实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“微前端qiankun改造实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

改造过程

首先我先用Vue2-admin-cli——我自己做的脚手架工具,创建两个vue-admin项目来演示,一个作为qiankun基座,另外一个就是我要引用的子应用。

全局安装脚手架npm install -g vue2-admin-cli # oryarn global add vue2-admin-cli创建项目vue2-admin-cli init <project_name>安装依赖yarn启动项目yarn serve

运行起来就是这样的

微前端qiankun改造实例分析

现在我们开始分别改造基座qiankun-base和子应用qiankun-vue,我想达到的效果是主应用qiankun-base只保留header sider footer的一个基本layout的布局,content部分全部加载子应用

qiankun-base

yarn add qiankun # 或者 npm i qiankun -S修改package.JSON启动命令修改启动端口"serve": "vue-cli-service serve --port 80 --open"src/router/index.ts修改路由模式为history const createRouter = () =>  new VueRouter({    mode: "history",    routes: routes as any,  });修改vue.config.js   我这里之前用的路由模式是hash  上线配置了publicPath 导致改为history以后静态资源加载路径有问题所以修改module.exports = {  // publicPath: "./",    devServer: {    disableHostCheck: true, // 关闭host检查  },};

 在入口文件src/main.ts下注册微应用并启动:

import { reGISterMicroApps, start } from "qiankun";registerMicroApps([  {    name: "qiankunVue",    entry: "//localhost:8080", 子应用的启动端口修改为8080,基座使用80,不要相同    container: "#qiankunVue",  加载子应用的容器    activeRule: "/qiankunVue", 路由匹配规则  },]);// 启动 qiankunstart();

 在你要放置子应用的位置增加一个容器用于加载子应用 

src/components/layout/index.vue

<template>  <el-container direction="vertical" >    <Header />    <el-container >      <el-aside width="250px">        <Menu />      </el-aside>      <el-main>        <el-breadcrumb          separator-class="el-icon-arrow-right"          v-if="showBreadcrumb"        >          <template v-for="(route, index) in matchedRoutes">            <el-breadcrumb-item              v-if="                (route.meta && route.meta.breadcrumbTo === false) ||                index === matchedRoutes.length - 1              "              :key="route.path"            >              {{ route.meta.title }}            </el-breadcrumb-item>            <el-breadcrumb-item              v-else              :key="route.path"              :to="{ path: route.path }"            >              {{ route.meta.title }}            </el-breadcrumb-item>          </template>        </el-breadcrumb>        <!-- 本身的路由加载 -->        <router-view  />        <!-- 子应用加载容器 -->        <div id="qiankunVue"  />      </el-main>    </el-container>  </el-container></template>

 将主应用之前的路由配置进行修改,不渲染自己的内容了,因为要改成去加载子应用的内容才是我们想要的,我的左侧菜单栏sider也是用路由配置这份文件生成的,所以我只需要注释这些路由要渲染的components就行,让他只充当一个生成sider菜单栏的作用,但是注意要保留容器所在的layout,因为我的子应用加载容器在这里面,加载子应用之前你必须保证容器被加载了

src/router/config.ts

const routes: Array<IBaseRouter> = [  {    path: "/",    redirect: "/home",    hidden: true,  },  {    path: "/login",    name: "login",    hidden: true,    component: () => import("../views/Login.vue"),  },  //保证子应用加载时容器页面必须加载   {    path: "/qiankunVue/*",    name: "qiankunVue",    hidden: true,    component: Layout,  },  {    path: "/qiankunVue/home",    name: "home",    component: Layout,    redirect: "/qiankunVue/home/index",    meta: {      title: "首页",      icon: "el-icon-s-home",    },    children: [      {        path: "index",        name: "index",        hidden: true,        // component: () => import("../views/Home.vue"),        meta: {          title: "首页",          breadcrumb: false,        },      },      {        path: "bar/:width/:height",        name: "bar",        props: true,        hidden: true,        // component: () => import("@/components/echarts/Bar.vue"),        meta: {          title: "柱状图",          activeMenu: "/home/index",        },      },      {        path: "pie/:width/:height",        name: "pie",        props: true,        hidden: true,        // component: () => import("@/components/echarts/Pie.vue"),        meta: {          title: "饼图",          activeMenu: "/home/index",        },      },      {        path: "line/:width/:height",        name: "line",        props: true,        hidden: true,        // component: () => import("@/components/echarts/Line.vue"),        meta: {          title: "折线图",          activeMenu: "/home/index",        },      },    ],  },  .....  {    path: "*",    redirect: "/error/404",    hidden: true,  },];export default routes;

改完之后刷新看一看,这样基座项目就改造好了,保留了基本页面的框架,中间的内容到时候都由子应用来填充就行了

微前端qiankun改造实例分析

qiankun-vue

修改package.json启动命令修改启动端口

"serve": "vue-cli-service serve --port 8080 --open"

入口文件 src/main.ts 修改

let vm: any = null;function render(props: any = {}) {  const { container } = props;  vm = new Vue({    router,    store,    render: (h) => h(App),  }).$mount(container ? container.querySelector("#app") : "#app");}// 在被qiankun引用时 修改运行时的 `publicPath`if ((window as any).__POWERED_BY_QIANKUN__) {   __webpack_public_path__ = (window as any).__INJECTED_PUBLIC_PATH_BY_QIANKUN__;}// 独立运行时if (!(window as any).__POWERED_BY_QIANKUN__) {  render();}导出三个生命周期函数export async function bootstrap() {  console.log("[vue] vue app bootstraped");}export async function mount(props: any) {  console.log("[vue] props from main framework", props);  render(props);}export async function unmount() {  vm.$destroy();  vm.$el.innerhtml = "";  vm = null;}export default vm;

src/router/index.ts修改路由模式并增加base(和主应用设置的activeRule一致)

const createRouter = () =>  new VueRouter({    mode: "history",    base: "/qiankunVue",    routes: routes as any  });

 打包配置修改(`vue.config.js`)

module.exports = {  devServer: {    disableHostCheck: true, // 关闭host检查    headers: {      "Access-Control-Allow-Origin": "*", // 防止加载时跨域    },  },  configureWEBpack: {    output: {      library: "qiankunVue",      libraryTarget: "umd", // 把微应用打包成 umd 库格式    },  },};

基座和子应用都修改完以后刷新看看,控制台报错了

微前端qiankun改造实例分析

立马查看官方文档,发现是因为我的子应用加载容器在基座的某个路由页面即我的layout里面,文档里指出必须保证微应用加载时主应用这个路由页面也加载了,就很喜欢这种文档????????,于是立马改一改

注释之前qiankun-base注册子应用时的启动qiankun命令,改到路由页面layout里面启动
src/main.ts

// 启动 qiankun//start();src/components/layout/index.vueimport { start } from "qiankun"; mounted() {    if (!(window as any).qiankunStarted) {      (window as any).qiankunStarted = true;      start();    }  }

重新刷新看看,成功了????????,多少有点舒服了

微前端qiankun改造实例分析

接下来要做的就是把子应用再改造一下,在qiankun中就只需要展示子应用content的内容,单独运行的时候为了方便调试我们就保留layout布局。看了这么久的官方文档,我当然知道用它就可以做出判断__POWERED_BY_QIANKUN__,思路很清晰,冲他????????

qiankun-vue

src/components/layout/index.vue

<template>  <el-container direction="vertical" v-if="isQiankun">    <el-main>      <el-breadcrumb        separator-class="el-icon-arrow-right"        v-if="showBreadcrumb"      >        <template v-for="(route, index) in matchedRoutes">          <el-breadcrumb-item            v-if="              (route.meta && route.meta.breadcrumbTo === false) ||              index === matchedRoutes.length - 1            "            :key="route.path"          >            {{ route.meta.title }}            <!-- {{ route.path }} -->          </el-breadcrumb-item>          <el-breadcrumb-item            v-else            :key="route.path"            :to="{ path: route.path }"          >            {{ route.meta.title }}            <!-- {{ route.path }} -->          </el-breadcrumb-item>        </template>      </el-breadcrumb>      <router-view  />    </el-main>  </el-container>  <el-container direction="vertical"  v-else>    <Header />    <el-container >      <el-aside width="250px">        <Menu />      </el-aside>      <el-main>        <el-breadcrumb          separator-class="el-icon-arrow-right"          v-if="showBreadcrumb"        >          <template v-for="(route, index) in matchedRoutes">            <el-breadcrumb-item              v-if="                (route.meta && route.meta.breadcrumbTo === false) ||                index === matchedRoutes.length - 1              "              :key="route.path"            >              {{ route.meta.title }}              <!-- {{ route.path }} -->            </el-breadcrumb-item>            <el-breadcrumb-item              v-else              :key="route.path"              :to="{ path: route.path }"            >              {{ route.meta.title }}              <!-- {{ route.path }} -->            </el-breadcrumb-item>          </template>        </el-breadcrumb>        <router-view  />      </el-main>    </el-container>  </el-container></template><script lang="ts">import { Vue, Component } from "vue-property-decorator";import Header from "./Header.vue";import Menu from "./Menu.vue";// import { IBaseRouter } from "@/router/config";@Component({  name: "Layout",  components: { Header, Menu },})export default class Layout extends Vue {  private get showBreadcrumb() {    return this.$route?.meta?.breadcrumbAll !== false;  }  private get matchedRoutes() {    return this.$route.matched?.filter(      (v) => v.meta?.title && v?.meta?.breadcrumb !== false    );  }  private get isQiankun() {    return (window as any).__POWERED_BY_QIANKUN__;  }}</script><style lang="less" scoped></style>

看看效果 基座正常展示子应用

微前端qiankun改造实例分析

子应用单独运行也正常展示,并且丝毫不影响开发体验

微前端qiankun改造实例分析

读到这里,这篇“微前端qiankun改造实例分析”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网精选频道。

--结束END--

本文标题: 微前端qiankun改造实例分析

本文链接: https://www.lsjlt.com/news/341224.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 微前端qiankun改造实例分析
    本文小编为大家详细介绍“微前端qiankun改造实例分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“微前端qiankun改造实例分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。改造过程首先我先用vue2-a...
    99+
    2023-07-02
  • 微前端框架qiankun源码分析
    本文小编为大家详细介绍“微前端框架qiankun源码分析”,内容详细,步骤清晰,细节处理妥当,希望这篇“微前端框架qiankun源码分析”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。一、single-spa简介要...
    99+
    2023-07-05
  • 微前端qiankun改造日渐庞大的项目教程
    目录项目背景微前端的好处qiankun改造过程qiankun-baseqiankun-vue结尾项目背景 很多小伙伴在工作中都碰到过和我一样的场景,手上的某个项目越来越大,眼看着每次...
    99+
    2024-04-02
  • 微前端框架qiankun源码剖析之下篇
    目录引言四、沙箱隔离4.1 JS隔离1. Snapshot沙箱2. Legacy沙箱3. Proxy沙箱4.2 CSS隔离1. ShadowDOM2. Scoped CSS五、通信方...
    99+
    2023-02-09
    微前端框架qiankun剖析 微前端 qiankun
  • 微前端框架qiankun源码剖析之上篇
    目录引言一、single-spa简介二、qiankun简介三、子应用加载引言 注意: 受篇幅限制,本文中所粘贴的代码都是经过作者删减梳理后的,只为讲述qiankun框架原理而展示,...
    99+
    2023-02-09
    微前端框架qiankun剖析 微前端框架qiankun
  • 微前端qiankun沙箱实现源码解读
    目录前言LegacySandbox单实例沙箱ProxySandbox多实例沙箱SapshotSandbox 快照沙箱结束语前言 上篇我们介绍了微前端实现沙箱的几种方式,没看过的可以下...
    99+
    2024-04-02
  • web前端实例分析
    这篇文章主要介绍了web前端实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇web前端实例分析文章都会有所收获,下面我们一起来看看吧。正文这题的规则是这样的给定有一个 Add 函数,要...
    99+
    2023-06-27
  • 基于微前端qiankun的多页签缓存方案实践
    目录一、多页签是什么?1.1 单页面应用实现多页签1.2 使用qiankun进行微前端改造后,多页签缓存有什么不同二、方案选择2.1 方案一:多个子应用同时存在2.2 方案二:同一时...
    99+
    2022-11-13
    微前端qiankun多页签缓存 微前端qiankun
  • Flask Vue前后端分离实例分析
    这篇文章主要讲解了“Flask Vue前后端分离实例分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Flask Vue前后端分离实例分析”吧!vue官网:开源的 Javascript 框架...
    99+
    2023-07-02
  • 前端html的实例代码分析
    这篇“前端html的实例代码分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“前端html...
    99+
    2024-04-02
  • web前端面试题实例分析
    今天小编给大家分享一下web前端面试题实例分析的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。面试官:页面导入样式时,使用 l...
    99+
    2023-07-05
  • 前后端分离之VueJS前端的示例分析
    这篇文章给大家分享的是有关前后端分离之VueJS前端的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。前言前端用什么框架都可以,这里选择小巧的vuejs。要实现的功能很简单...
    99+
    2024-04-02
  • web前端与后端分离的架构实例分析
    本篇内容主要讲解“web前端与后端分离的架构实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“web前端与后端分离的架构实例分析”吧!一、关于前端的 dat...
    99+
    2024-04-02
  • CSS filter与前端滤镜实例分析
    本篇内容介绍了“CSS filter与前端滤镜实例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  ...
    99+
    2024-04-02
  • Css前端的示例分析
    这篇文章将为大家详细讲解有关Css前端的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、移动端移动端还没有上车。先来总结一下三个基本的移动端开发特性:视口(vi...
    99+
    2024-04-02
  • Vue微信授权登录前后端分离的示例分析
    小编给大家分享一下Vue微信授权登录前后端分离的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!微信授权登录是一个非常常见...
    99+
    2024-04-02
  • web前端面试题实例代码分析
    这篇文章主要讲解了“web前端面试题实例代码分析”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“web前端面试题实例代码分析”吧!面试官:给定一个元素,如何实现水平垂直居中?我:呃~,针对这个...
    99+
    2023-07-05
  • 高频web前端面试题实例分析
    本篇内容主要讲解“高频web前端面试题实例分析”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“高频web前端面试题实例分析”吧!面试官:请你简述 var、let、const 三者之间的区别?我:呃...
    99+
    2023-07-05
  • web前端常见面试题实例分析
    这篇文章主要介绍“web前端常见面试题实例分析”,在日常操作中,相信很多人在web前端常见面试题实例分析问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”web前端常见面试题实例...
    99+
    2024-04-02
  • 前端react面试题实例代码分析
    这篇“前端react面试题实例代码分析”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“前端react面试题实例代码分析”文章吧...
    99+
    2023-07-05
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作