位置: IT常识 - 正文

微前端-qiankun:vue3-vite 接入 vue3、nuxt3、vue2、nuxt2等子应用(微前端的好处和缺陷)

编辑:rootadmin
微前端-qiankun:vue3-vite 接入 vue3、nuxt3、vue2、nuxt2等子应用

推荐整理分享微前端-qiankun:vue3-vite 接入 vue3、nuxt3、vue2、nuxt2等子应用(微前端的好处和缺陷),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:什么是微前端,微前端和微服务,无界微前端,微前端microapp官网,qiankun微前端,无界微前端,微前端和微服务,什么是微前端,内容如对您有帮助,希望把文章链接给更多的朋友!

一、了解qiankun.js

qiankun - qiankun

1.1、简单,任意 js 框架均可使用。微应用接入像使用接入一个 iframe 系统一样简单,但实际不是 iframe。

1.2、完备,几乎包含所有构建微前端系统时所需要的基本能力,如 样式隔离、js 沙箱、预加载等。解耦,与技术无关。

1.3、生产可用,已在蚂蚁内外经受过足够大量的线上系统的考验及打磨,健壮性值得信赖。

1.4、qiankun 是一个基于 single-spa 的微前端实现库,旨在帮助大家能更简单、无痛的构建一个生产可用微前端架构系统。

1.5、qiankun 孵化自蚂蚁金融科技基于微前端架构的云产品统一接入平台,目前 qiankun 已在蚂蚁内部服务了超过 2000+ 线上应用,在易用性及完备性上,绝对是值得信赖的。

1.6、微前端概念

微前端是一种多个团队通过独立发布功能的方式来共同构建现代化 web 应用的技术手段及方法策略。

1.7、核心价值:

介绍 - qiankun

1.7.1、技术栈无关:主框架不限制接入应用的技术栈,微应用具备完全自主权

1.7.2、独立开发、独立部署:微应用仓库独立,前后端可独立开发,部署完成后主框架自动完成同步更新

1.7.3、增量升级:在面对各种复杂场景时,我们通常很难对一个已经存在的系统做全量的技术栈升级或重构,而微前端是一种非常好的实施渐进式重构的手段和策略

1.7.4、独立运行时:每个微应用之间状态隔离,运行时状态不共享

1.8、特性

1.8.1、基于 single-spa 封装,提供了更加开箱即用的 API。

1.8.2、技术栈无关,任意技术栈的应用均可 使用/接入,不论是 React/Vue/Angular/JQuery 还是其他等框架。可以对老jQuery项目进行升级,老业务不变,新页面使用vue3,这样就好了,目前没有看到相关的资料,看到一些资料是遇到问题的,比如全局变量丢失等,待研究。

1.8.3、HTML Entry 接入方式,让你接入微应用像使用 iframe 一样简单。

1.8.4、样式隔离,确保微应用之间样式互相不干扰。

1.8.5、JS 沙箱,确保微应用之间 全局变量/事件 不冲突。

1.8.6、资源预加载,在浏览器空闲时间预加载未打开的微应用资源,加速微应用打开速度。

1.8.7、 umi 插件,提供了 @umijs/plugin-qiankun 供 umi 应用一键切换成微前端架构系统。

二、安装

yarn add qiankun

npm i qiankun

pnpm add qiankun

只需要在基座项目安装qiankun,子应用不需要安装。 

三、使用,qiankun官网demo

import { loadMicroApp } from 'qiankun';// 加载微应用loadMicroApp({ name: 'reactApp', entry: '//localhost:7100', container: '#container', props: { slogan: 'Hello Qiankun', },});

四、实战

项目实践 - qiankun

4.1、vue3,基座项目/主应用/main-app

4.1.1、创建项目

npm init vue@latest

4.1.2、安装乾坤

pnpm add qiankun

4.1.3、main.ts注册微应用

import { registerMicroApps, addGlobalUncaughtErrorHandler, start } from 'qiankun';// 注册子应用registerMicroApps([ { name: 'subApp', entry: '//localhost:3000', container: '#subAppContainerVue3', // 和app.vue配置的节点 activeRule: '/subAppVue3', // 访问:http://localhost:5174/subAppVue3 props: { mag: '我是主应用main' // 主应用向微应用传递参数 } } // 再有其他子应用,同理]);// 启动 qiankunstart({ prefetch:'all', // 预加载 sandbox: { experimentalStyleIsolation: true, // 开启沙箱模式,实验性方案 },});// 添加全局异常捕获addGlobalUncaughtErrorHandler((handler) => { console.log("异常捕获", handler);});

4.1.4、app.vue创建挂载节点,再有其他子应用,同理

<div id="subAppContainerVue3"></div>

经过测试,主应用成功。

4.2、vue3-vite主应用 接入 vue3-vite子应用

微前端-qiankun:vue3-vite 接入 vue3-vite_snow@li的博客-CSDN博客

4.3、vue3-vite主应用 接入 vue3-webpack子应用

微前端-qiankun:乾坤接入vue3-webpack_snow@li的博客-CSDN博客

4.4、vue3-vite主应用 接入 vue2子应用

微前端-qiankun:vue3-vite 接入 nuxt2_snow@li的博客-CSDN博客

微前端-qiankun:vue3-vite 接入 vue3、nuxt3、vue2、nuxt2等子应用(微前端的好处和缺陷)

4.5、vue3-vite主应用 接入 html子应用

待补充

4.6、vue3-vite主应用 接入 jQuery子应用

不要对 iframe 抱有偏见,它也是微前端的一种实现方式,如果页面上无弹窗、无全屏等操作,iframe 也是很好用的。配置缓存和 cdn 加速,如果是内网访问,也不会很慢。 iframe 和 qiankun 可以并存,jQuery 多页应用使用 iframe 接入就挺好,什么时候什么场景该用哪种方案,具体情况具体分析。

最后,文章有什么问题或错误欢迎指出,谢谢!

微前端方案 qiankun(实践及总结)--摘抄 - 建站教程

jquery项目嵌入vue3框架_jquery vue3_卷大爷的博客-CSDN博客

4.7、vue3-vite主应用 接入 nuxt2子应用

微前端-qiankun:vue3-vite 接入 nuxt2_snow@li的博客-CSDN博客

4.8、nuxt2主应用 接入 nuxt2子应用

微前端-qiankun:nuxt2 接入 nuxt2_snow@li的博客-CSDN博客

4.9、vue3-vite主应用 接入 nuxt3子应用

待补充

4.10、nuxt作为主应用

https://www.cnblogs.com/rain-watcher/p/16938611.html

4.11、当子应用同时作为基座应用时

vue3 + vite + qiankun - 简书

五、过程记录

5.1、子应用qiankun做了样式隔离,父子应用样式隔离可以使用如下方法

默认情况下切换应用会采用动态样式表,加载的时候添加样式,删除的时候卸载样式(子应用之家的样式隔离)

主应用和子应用如何隔离(我们通过BEM规范)->(cssmodules)动态生成一个前缀(并不是完全隔离)

shadowDOM video 标签中的 快进 放大功能 增加全局样式就会有问题

六、乾坤项目服务器部署

所有项目,包括基座项目,业务项目都在服务器可以独立部署。

qiankun从接入到部署(nuxt篇) - 掘金

详细待研究。不能被卡脖子。

七、欢迎交流指正,关注我,一起学习。

 参考链接:

SingleSpa及qiankun入门、源码分析及案例

https://www.cnblogs.com/Mr-Rshare/p/16571760.html

vue3 + vite + qiankun - 简书

Vue3,Vite,TypeScript,Monorepo,qiankun...... Buff叠满,BUG没有_qiankun vue3 vite_web老猴子的博客-CSDN博客

vue3 (三) qiankun+子应用(主应用)_vue3 qiankun_飞天代码的博客-CSDN博客

vue3+阿里乾坤实现主应用和微应用_乾坤微应用_花无缺001的博客-CSDN博客

07. vue3+vite+qiankun搭建微应用前端框架,并接入vue3微应用_vue微应用_qq_29517595的博客-CSDN博客

vue乾坤快速入门_哔哩哔哩_bilibili

微前端qiankun快速入门_哔哩哔哩_bilibili

qiankun从接入到部署(nuxt篇) - 掘金

关于qiankun的使用与部署过程,全详细记录_qiankun打包部署_朝花夕实的博客-CSDN博客

微前端qiankun的源码实现_哔哩哔哩_bilibili

如何设计实现微前端框架-qiankun

看滴普大前端是如何玩转基于“qiankun”(乾坤)的微前端架构的_应用

qiankun.js应用_小三金的博客-CSDN博客_qiankun.js

微前端qiankun的实战_哔哩哔哩_bilibili

GitHub - umijs/qiankun: 📦 🚀 Blazing fast, simple and complete solution for micro frontends.

qiankun - qiankun

GitHub - kakajun/qiankun-vite-test: 技术站: vue3+vite+qiankun+lenar,父应用 vue3(vite),子应用用 vue(webpack) 和 vue3(webpack)和vue3(vite), 可以稍加修改作为中小型应用模板

vue项目落地(qiankun.js)微前端服务 - 知乎

微前端方案 qiankun(实践及总结)--摘抄 - 建站教程

本文链接地址:https://www.jiuchutong.com/zhishi/292398.html 转载请保留说明!

上一篇:Transformers 库的基本使用(transformers document)

下一篇:鸟瞰罗卡附近的Grotta della Poesia,意大利莱切 (© Amazing Aerial Agency/Offset by Shutterstock)(罗卡购物村)

  • 微信折叠群聊还能收到消息吗(微信折叠群聊还会收到艾特吗)

    微信折叠群聊还能收到消息吗(微信折叠群聊还会收到艾特吗)

  • 拼多多自提货怎么自提(拼多多自提货怎么退款)

    拼多多自提货怎么自提(拼多多自提货怎么退款)

  • 小爱助理通话怎么关闭(小爱助理通话怎么关闭 note8)

    小爱助理通话怎么关闭(小爱助理通话怎么关闭 note8)

  • 小米10充满电需要多长时间呢(小米10冲满电要多久)

    小米10充满电需要多长时间呢(小米10冲满电要多久)

  • word怎么升序排列表格内容(word怎么进行升序排列)

    word怎么升序排列表格内容(word怎么进行升序排列)

  • 荣耀路由x2和x2增强版区别(荣耀路由X2和荣耀路由2s)

    荣耀路由x2和x2增强版区别(荣耀路由X2和荣耀路由2s)

  • vivo手机有siri功能吗(vivo的siri在哪)

    vivo手机有siri功能吗(vivo的siri在哪)

  • 荣耀v30怎么装手机卡(荣耀v30怎么装手写笔)

    荣耀v30怎么装手机卡(荣耀v30怎么装手写笔)

  • 掌上12333注册不了(掌上12333注册不了获取验证码失败,检查网络连接)

    掌上12333注册不了(掌上12333注册不了获取验证码失败,检查网络连接)

  • qq头像跟点赞头像显示不一样(qq头像跟点赞头像的区别)

    qq头像跟点赞头像显示不一样(qq头像跟点赞头像的区别)

  • 微信网络异常连接失败什么意思(微信网络出现异常)

    微信网络异常连接失败什么意思(微信网络出现异常)

  • 联发科x20相当于骁龙什么处理器(联发科x20相当于苹果a几)

    联发科x20相当于骁龙什么处理器(联发科x20相当于苹果a几)

  • 闹铃怎么设置(闹铃怎么设置振动)

    闹铃怎么设置(闹铃怎么设置振动)

  • 手机无法开启数据连接(手机无法开启数据传输)

    手机无法开启数据连接(手机无法开启数据传输)

  • 微信提示上传身份证是什么意思(微信提示上传身份证不上传会怎么样)

    微信提示上传身份证是什么意思(微信提示上传身份证不上传会怎么样)

  • 手机号码注销了还能查到信息吗(手机号码注销了微信密码忘了怎么办)

    手机号码注销了还能查到信息吗(手机号码注销了微信密码忘了怎么办)

  • 魅族16sPro应用分身在哪(魅族16th应用小窗怎样设置)

    魅族16sPro应用分身在哪(魅族16th应用小窗怎样设置)

  • 删除退群后消息还在吗(删除退出群聊后消息会消失吗)

    删除退群后消息还在吗(删除退出群聊后消息会消失吗)

  • 天猫津贴可以买手机吗(天猫购物津贴能在淘宝所有店铺使用吗?)

    天猫津贴可以买手机吗(天猫购物津贴能在淘宝所有店铺使用吗?)

  • 发微信语音对方忙线中(发微信语音对方无应答是怎么回事)

    发微信语音对方忙线中(发微信语音对方无应答是怎么回事)

  • 怎么把图片转成文档(怎么把图片转成cad图)

    怎么把图片转成文档(怎么把图片转成cad图)

  • vlig是什么(vili是什么意思)

    vlig是什么(vili是什么意思)

  • win11安装组策略编辑器ADMX模板的方法步骤(win11 组策略)

    win11安装组策略编辑器ADMX模板的方法步骤(win11 组策略)

  • itouch.exe是什么进程 itouch进程查询(ui.exe啥意思)

    itouch.exe是什么进程 itouch进程查询(ui.exe啥意思)

  • 如何修改纳税申报密码
  • 土地出让金印花税计税依据
  • 8.会计核算方法具体包括哪些内容?
  • 收据能入账抵税吗
  • 农产品普通发票抵扣政策
  • 卷烟批发环节消费税税率
  • 房产租赁合同印花税
  • 平销返利如何开红字发票
  • 公司租赁的车辆发生的费用都可以报销吗?
  • 补计提个税的会计分录
  • 增值税和实际缴税不符
  • 租赁厂房发生的改造装修费用
  • 持有至到期投资改名为
  • 企业土地是不是都应该缴纳房产税?
  • 支付运费价税合计
  • 实收资本印花税是一年一交吗
  • 公司代扣的社保怎么做分录
  • 哪些外籍个人应在中国缴纳个税?
  • 增值税普通发票红冲之后还能查询吗
  • 公司房租押金收不回来账务处理
  • 个人收回转让的股权个税应如何处理?
  • 退税技术有什么影响
  • 企业结算备付金怎么做账
  • 查补的增值税如何申报
  • 存续在业有什么区别
  • 在linux操作系统中
  • php正则匹配字符串
  • 暂存款转结余
  • 私款转入公司账户怎么办
  • 支付公司保洁费未开发票
  • PHP:Memcached::fetch()的用法_Memcached类
  • 怎样做好固定资产管理工作
  • 代开票作废税未退该如何分录?
  • 旅游企业会计ppt
  • 现金流方法
  • 房产税城镇土地使用税申报期限
  • 房地产企业如何计算土地使用税
  • 二连浩特老照片
  • 房地产企业土地出让金抵减销项税额
  • thinkphp count
  • vscode怎么写前端代码
  • 怎么冲暂估入账
  • 补缴去年的税款会计分录
  • 行政事业单位其他应收款核销分录
  • python爬虫入门教程
  • php验证码代码怎么写
  • puthon zip函数
  • 小规模纳税人成本含税吗
  • mysql分页优化原理
  • sql dbo
  • 企业注册资本的规定
  • 应收账款和应付账款属于什么科目
  • 货物已到发票未到怎么做账
  • 应收应付抹零账务处理
  • 帮别人维修东西怎么开票
  • 帮别人注册医疗器械法人有风险吗
  • 企业购车购置税怎么算
  • 企业一般账户开户申请理由
  • 原股东决定
  • 建账有哪些步骤,每个步骤有哪些注意事项
  • bat windows
  • 电脑太慢了怎么解决
  • linux用户权限管理
  • win8.1连接wifi
  • xp安装盘复制u盘
  • linux如何使用uname命令
  • Win7系统怎么打开文件后缀名
  • win7屏幕不停闪烁
  • unity 3d教程
  • linux中切换目录命令符
  • Shell脚本监控日志 出现关键字 grep提醒
  • unity 更新
  • unity 静态函数
  • python常用的内置逻辑判断函数
  • javastudio
  • 领导班子和领导干部评议意见表
  • 规范性文件失效后,没有新文件,可以使用民法典第十条吗
  • 扣缴个人所得税怎么计算
  • 大管家多少集
  • 印花税票在哪里可以查到
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设