MicroApp小试牛刀

MicroApp部署(父子均是vite+vue3)

父应用:

首先在父应用中安装microApp

npm i @micro-zoe/micro-app --save
  1. main.js配置

    🚀 特别需要注意的是:为了兼容vite,需要在启动中配置对应的插件,注意第一处注释中examcenter为中的name值,第二处见注释。

import microApp from '@micro-zoe/micro-app'

microApp.start({
  plugins: {
    modules: {
      // 此处examcenter即应用的name值
      examcenter: [{
        loader(code) {
          if (process.env.NODE_ENV === 'development') {
            // 这里 examcenter 需要和子应用vite.config.js中base的配置保持一致
            code = code.replace(/(from|import)(\s*['"])(\/examcenter\/)/g, all => {
              return all.replace('/examcenter/', 'http://localhost:8020/examcenter/')
            })
          }
          return code
        }
      }]
    }
  }
})
  1. view配置
<micro-app name='examcenter' url='http://localhost:8020/' inline disableSandbox ></micro-app>
  1. route.js配置

    🐼 需要注意父应用提供一个动态路由留给子应用!

{
    path: '/examcenter:page*',
    name: 'examcenter',
    component: () => import('/@/views/exam/index.vue'),  
}

子应用

  1. vite.config.js (注意两处核心配置注释)
import { defineConfig, loadEnv } from 'vite'
import path from 'path'
import createVitePlugins from './vite/plugins'

// https://vitejs.dev/config/
export default defineConfig(({ mode, command }) => {
  const env = loadEnv(mode, process.cwd())
  return {
    base: '/examcenter',
    plugins: [createVitePlugins(env, command === 'build'),
    /**
    * 核心配置 自定义插件!
    */
    (function () {
      let basePath = ''
      return {
        name: "vite:micro-app",
        apply: 'build',
        configResolved(config) {
          basePath = `${config.base}${config.build.assetsDir}/`
        },
        writeBundle (options, bundle) {
          for (const chunkName in bundle) {
            if (Object.prototype.hasOwnProperty.call(bundle, chunkName)) {
              const chunk = bundle[chunkName]
              if (chunk.fileName && chunk.fileName.endsWith('.js')) {
                chunk.code = chunk.code.replace(/(from|import\()(\s*['"])(\.\.?\/)/g, (all, $1, $2, $3) => {
                  return all.replace($3, new URL($3, basePath))
                })
                const fullPath = join(options.dir, chunk.fileName)
                writeFileSync(fullPath, chunk.code)
              }
            }
          }
        },
      }
    })(),
    ],
    resolve: {
      // https://cn.vitejs.dev/config/#resolve-alias
      alias: {
        // 设置路径
        '~': path.resolve(__dirname, './'),
        // 设置别名
        '@': path.resolve(__dirname, './src')
      },
      // https://cn.vitejs.dev/config/#resolve-extensions
      extensions: ['.mjs', '.js', '.ts', '.jsx', '.tsx', '.json', '.vue']
    },
	// vite 相关配置
    server: {
      port: 8020,
      host: true,
      open: true,
      /**
      * 核心配置 应用之间跨域访问!
      */
      headers: {
        'Access-Control-Allow-Origin': '*',
      },
    },
  }
})
  1. 入口main.js

    🎨 封装挂载和销毁函数,注意window[‘micro-app-xxx’] 中 ‘xxx’ 要与前面设定的name一致

let app = null;
function mount() {
  app = createApp(App);

  // 全局方法挂载
  // app.XXX
    
  directive(app);

  app.mount("#my-vite-app");
  
  console.log("微应用child-vite渲染了")
}

// 将卸载操作放入 unmount 函数
function unmount() {
  app?.unmount();
  // 卸载所有数据监听函数
  window.eventCenterForAppNameVite?.clearDataListener();
  app = null;
  console.log("微应用child-vite卸载了");
}

// 微前端环境下,注册mount和unmount方法
if (window.__MICRO_APP_BASE_APPLICATION__) {
  // @ts-ignore
  window['micro-app-examcenter'] = { mount, unmount }
} else {
  // 非微前端环境直接渲染
  mount()
}

注明:

(历史原因)MicroApp并未对vite有较多的支持,其中样式隔离,js沙箱等特性均失效!此外qiankun框架对vite的支持度更低,不使用插件基本无法使用vite。介于此种原因,故采用京东的MicroApp框架,人为干涉样式隔离!

🎄 父子通信方式暂未加入,后续补充;样式无法会进行相互污染,暂未隔离

MicroApp 微前端是一种软件架构模式,它允许开发者构建大型应用的同时保持高度模块化和解耦。在这种架构下,应用程序可以由多个独立、自主管理的小型应用(即 MicroApps)组成,每个 MicroApp 都拥有自己的渲染逻辑、状态管理、路由系统等。这种设计能够促进团队协作效率、提高系统的维护性和可扩展性。 ### MicroApp 的特点: 1. **模块化**:每个 MicroApp 可以独立部署、升级和维护,减少了对整个系统的影响。 2. **复用性**:共享功能和组件可以在不同的 MicroApp 中重用,降低开发成本并提高代码质量。 3. **灵活性**:由于各个部分相互独立,可以根据需要添加、删除或修改特定功能而不会影响其他部分。 4. **高性能**:通过仅加载所需的 MicroApp 部分到用户界面,可以提升整体性能和响应速度。 5. **安全隔离**:每个 MicroApp 都有其独立的安全边界,提高了系统的整体安全性。 ### 实现方式: 实现 MicroApp 微前端的方式通常包括引入前端框架和库如 React、Angular、Vue 等,以及相应的工具和技术栈,比如使用 Webpack 进行打包、使用 SPA (单页应用) 技术处理路由切换、使用服务端渲染技术增强 SEO 等。关键在于如何将这些小型应用集成在一起,协同工作,并确保它们之间的通信流畅、数据同步准确。 ### 应用场景: - 开发复杂的企业级应用,便于团队分工合作。 - 实现快速迭代,只需更新受影响的 MicroApp 即可,无需重启整个应用。 - 提高应用的可测试性和稳定性,因为每个小应用都是相对独立且容易测试的单元。 ### 结论: MicroApp 微前端提供了一种现代化的应用构建策略,强调了敏捷开发、高效协作与持续优化的核心价值。随着技术的发展和需求的变化,这种架构模式在现代软件工程领域得到了广泛的认可和采用。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值