• vite+vue3+ts项目搭建之集成qiankun让其成为子应用模板


    vite+vue3+ts项目搭建之集成qiankun让其成为子应用模板

    安装依赖

    npm install vite-plugin-qiankun
    
    • 1

    vite.config.ts文件修改,代码如下:

    import qiankun from 'vite-plugin-qiankun'
    const packName = require('./package').name  // 必须要指定当前子应用命名
     // 配置NG——这个是与后台、运维约定好的,做NG转发;即主应用地址+子应用base就会直接NG转发
      base: '/vitedemo',
     plugins: [
      // 配置qiankun
        qiankun(`${packName}`, {
          useDevMode: true
        }),
        ...
     ]
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12

    本地启动测试主子应用切换需要在server:{}里面添加headers: {‘Access-Control-Allow-Origin’: ‘*’ }, 解决主应用跳子应用跨域问题

    server: {
        headers: {
          'Access-Control-Allow-Origin': '*'
        },
        host: '0.0.0.0',
        port,
        open: true,
        https: false,
        ...
       }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11

    main.ts文件修改,完整代码如下:

    import { createApp } from 'vue'
    import App from './App.vue'
    import router from './router'
    // 所有业务api接口
    import api from './api'
    /**
     * element-plus
     */
    import ElementPlus from 'element-plus'
    import 'element-plus/dist/index.css'
    // 因element-plus默认是英文,我们指定一下默认中文
    import locale from 'element-plus/lib/locale/lang/zh-cn'
    // 图标并进行全局注册
    import * as ElementPlusIconsVue from '@element-plus/icons-vue'
    // pinia代替vuex
    import pinia from './store'
    // 权限控制(全局路由守卫)
    import './permission'
    /**
     * 样式
     */
    // 公共样式
    import '@/assets/styles/index.scss'
    // 初始化样式
    import 'normalize.css'
    // 统一注册 baseComponents
    import baseComponentsInstall from '@/components/baseComponents/install'
    // svg渲染
    import SvgIcon from '@/components/SvgIcon/index.vue'
    /**
     * 配置qiankun
     */
    import { renderWithQiankun, qiankunWindow } from 'vite-plugin-qiankun/dist/helper'
    let instance: any = null
    function render(props: any = {}) {
      const { container } = props
      instance = createApp(App)
      instance.use(router)
      instance.use(pinia)
      // 注册全局api方法
      instance.config.globalProperties.$api = api
      // 注册所有图标
      for (const [key, component] of Object.entries(ElementPlusIconsVue)) {
        instance.component(key, component)
      }
      // 注册ElementPlus
      instance.use(ElementPlus, {
        locale // 语言设置
        // size: Cookies.get('size') || 'medium' // 尺寸设置
      })
      // 自动注册全部本地组件
      instance.use(baseComponentsInstall)
      // 全局组件祖册
      instance.component(
        'SvgIcon',
        // 如果这个组件选项是通过 `export default` 导出的,那么就会优先使用 `.default`,否则回退到使用模块的根
        SvgIcon.default || SvgIcon
      )
      instance?.mount(container ? container.querySelector('#app') : '#app')
      console.log('开始加载相关内容')
    }
    renderWithQiankun({
      mount(props: any) {
        render(props)
      },
      bootstrap() {
        console.log('%c', 'color:green;', ' ChildOne bootstrap')
      },
      update() {
        console.log('%c', 'color:green;', ' ChildOne update')
      },
      unmount(props: any) {
        console.log('unmount', props)
        instance.unmount()
        instance._container.innerHTML = ''
        instance = null
      }
    })
    if (!qiankunWindow.__POWERED_BY_QIANKUN__) {
      console.log('并不是qiankun渲染')
      render()
    }
    
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • 31
    • 32
    • 33
    • 34
    • 35
    • 36
    • 37
    • 38
    • 39
    • 40
    • 41
    • 42
    • 43
    • 44
    • 45
    • 46
    • 47
    • 48
    • 49
    • 50
    • 51
    • 52
    • 53
    • 54
    • 55
    • 56
    • 57
    • 58
    • 59
    • 60
    • 61
    • 62
    • 63
    • 64
    • 65
    • 66
    • 67
    • 68
    • 69
    • 70
    • 71
    • 72
    • 73
    • 74
    • 75
    • 76
    • 77
    • 78
    • 79
    • 80
    • 81
    • 82
    • 83
  • 相关阅读:
    系统架构设计师(第二版)学习笔记----需求工程
    第五章:java构造方法与对象创建
    行业早报6.5
    SpringCloudAlibaba之Sentinel介绍
    express创建服务器,以及前后端联调
    线程的概述
    以太坊合并在即 生态用户需要注意什么?
    【CSS】包含块
    Linux TCP/IP内核参数调优,网络高延迟大吞吐。
    JVM原理和优化
  • 原文地址:https://blog.csdn.net/weixin_47000834/article/details/133707303