当前位置: 首页 > ai >正文

使用qianjkun uniapp 主应用 集成 vue微应用

uniapp 主应用 集成 vue微应用

乾坤官方文档

主应用为uniapp

在主应用安装qiankun框架

yarn add qiankun 
#或者
npm install qiankun

因为我们需要动态传递数据,则使用loadMicroApp方法动态加载
pages/work/preview/index页面文件

<template><view class="preview-container"><view class="micro-wrap"><div id="micro-container"></div></view></view>
</template><script>
let microApp = null
import { loadMicroApp } from 'qiankun';
import { getInfo } from '@/api/login'
import actions from '../../../share/actions';
export default {components: {},data() {return {loading: false,previewId: 1}},async onLoad() {await this.init()},async onUnload() {if (microApp) {await microApp.unmount()microApp = null}},methods: {async init() {this.loading = trueactions.setGlobalState({previewId: this.previewId})await this.mountSub()},async mountSub() {const resp = await getInfo();// 获取系统信息const systemInfo = uni.getSystemInfoSync();microApp = loadMicroApp({name: 'test',entry: 'http://localhost/', //不要写路由 hashcontainer: '#micro-container',props: {userInfo: resp.data,systemInfo,onGlobalStateChange: actions.onGlobalStateChange,setGlobalState: actions.setGlobalState},sandbox: {experimentalStyleIsolation: true //强制性的样式沙箱隔离}})await microApp.mountPromisethis.loading = false}}
}
</script><style scoped>
.micro-wrap {overflow: hidden;height: calc(100vh - 44px);width: 100%;
}
</style>

share/actions.js文件

import {initGlobalState
} from 'qiankun';// 主应用中注册全局事件
// 设置全局状态
const initialState = {currentTab: 0,zoomScale: 1,mobile: true
};
// 创建全局状态实例并导出
const actions = initGlobalState(initialState);
// 监听全局状态变化(可选)actions.onGlobalStateChange((newState, prev) => {console.log('主应用监听到全局状态变化:', newState, prev);});
export default actions;

微应用

1.在 src 目录新增 public-path.js

if (window.__POWERED_BY_QIANKUN__) {__webpack_public_path__ = window.__INJECTED_PUBLIC_PATH_BY_QIANKUN__;
}

2.入口文件 main.js 修改,为了避免根 id #app 与其他的 DOM 冲突,需要限制查找范围。

import './public-path'; // 需要放在第一行,不然icon图标会显示不出不来
import store from './store'
import { isMobile } from '@/utils'
let instance = null
/** ================微前端配置================ */
// 如果是在乾坤里面加载,则子应用应该跳过默认的加载逻辑,让主应用来控制当前应用的加载(匹配到子应用的路由标识)
if (!window.__POWERED_BY_QIANKUN__) {render({});
}
function render(props = {}) {const { container, userInfo, systemInfo } = propsif (userInfo) {store.dispatch('setUserInfo', userInfo)}if (systemInfo) {// 手机样式if (isMobile(systemInfo.ua)) {document.body.classList.add('ua-mobile');} else {document.body.classList.add('ua-pc');}}// 监听主应用推过来的全局状态(true = 首次立即触发一次)props.onGlobalStateChange && props.onGlobalStateChange((state, prev) => {//更新 vuex / 组件状态 / 重新拉数据等store.dispatch('qiankun/setQkState', state)}, true) // true 表示进来就触发一次// 子应用也可以反向通知主应用// props.setGlobalState && props.setGlobalState({ childReady: true })instance = new Vue({el: container ? container.querySelector('#app') : '#app',router,store,render: h => h(App)})
}// qiankun 生命周期
export async function bootstrap() {console.log('app bootstraped');
}
export async function mount(props) { render(props) }
export async function unmount() {instance.$destroy()instance.$el.innerHTML = ''instance = null
}

src\store\modules\qiankun.js状态文件

const state = () => ({qiankunState: {}   // 主应用下发的全局状态
})
const mutations = {SET_QK_STATE(state, payload) {state.qiankunState = { ...state.qiankunState, ...payload }}
}
const actions = {setQkState({ commit }, payload) {commit('SET_QK_STATE', payload)}
}
export default { namespaced: true, state, mutations, actions }

监听状态变化,在vue文件里面加下下面的代码

 computed: {...mapState({// 箭头函数会使代码更简练currentTab: state => state.qiankun.qiankunState.currentTab,zoomScale: state => state.qiankun.qiankunState.zoomScale})},watch: {currentTab(newVal, oldVal) {conslole.log(newVal, oldVal)},zoomScale(newVal, oldVal) {conslole.log(newVal, oldVal)}},

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

const packageName = require('./package.json').name;
module.exports = {devServer: {headers: {'Access-Control-Allow-Origin': '*',},},configureWebpack: {output: {library: `${packageName}-[name]`,libraryTarget: 'umd', // 把微应用打包成 umd 库格式jsonpFunction: `webpackJsonp_${packageName}`, // webpack 5 需要把 jsonpFunction 替换成 chunkLoadingGlobal},},
};

4.新建路由

{path: '/pages',component: Layout,hidden: true,redirect: 'noredirect',children: [{meta: {title: '微前端',},path: 'work/preview/index',// component: (resolve) => require(['@/views/hardware/manage/index'], resolve),component: (resolve) => require(['@/views/app/preview'], resolve),name: 'AppPreview',meta: {title: '微前端页面', icon: '', noCache: true}}]},

注意: 这里的路由地址需要与uniapppages/work/preview/index路径对应上

http://www.xdnf.cn/news/18920.html

相关文章:

  • 8.28作业
  • 可改善能源利用水平、削减碳排放总量,并为可再生能源规模化发展提供有力支撑的智慧能源开源了
  • Python Imaging Library (PIL) 全面指南:Python Imaging Library (PIL)基础图像处理入门
  • 【图像处理基石】DCT在图像处理中的应用及实现
  • 从零开始学习JavaWeb-20
  • 第二十节:3D文本渲染 - 字体几何体生成与特效
  • Node.js终极文本转图指南
  • 使用 Action 自动部署 VuePress 到 GitHub Pages
  • Webdriver-Manager 4.0.1启动错误解决
  • Komo Searc-AI驱动的搜索引擎
  • 区块链+隐私计算护航“东数西算”数据安全报告
  • 20.22 QLoRA微调实战:中文语音识别数据准备全流程解密
  • hintcon2025No Man‘s Echo
  • 国产芯力量!贴片式SD卡搭载北京君正Rk瑞芯微,打造嵌入式存储低延迟+高可靠黄金组合​
  • 《从应用到内核:三种流量转发方案深度对比》
  • 手机上访问你电脑上的前端项目
  • 机器学习和高性能计算中常用的几种浮点数精度
  • ​突破RAG知识库中的PDF解析瓶颈:从文本错乱到多模态处理的架构跃迁​
  • 面试tips--JVM(2)--对象创建的过程
  • SLF4J和LogBack
  • 工业级TF卡NAND + 北京君正 + Rk瑞芯微的应用
  • @Jenkins 介绍、部署与使用标准作业程序
  • Gin Validator 错误信息翻译与自定义校验规则详解
  • VS2022+QT6.7+Multimedia(捕获Windows音频数据,生成实时频谱)
  • 浅谈JMeter Listener
  • 安宝特方案丨AR异地专家远程支持平台,适合:机电运维、应急处置、监造验收
  • esp32c2 at 请问通过HTTPS进行OTA升级的AT命令流程有吗?
  • ERNIE 学习
  • Linux中Java后端调用外部进程 未处理后台输出流 导致io阻塞问题解决方法
  • Mac训练大模型:MLX-LM框架LoRA训练Qwen3并集成SwanLab进行可视化