位置: 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)(罗卡购物村)

  • 空调清洗怎么做广告(空调清洗怎么清洗)(空调清洗教程)

    空调清洗怎么做广告(空调清洗怎么清洗)(空调清洗教程)

  • 苹果微信怎么设置微信钱包锁(苹果微信怎么设置置顶)

    苹果微信怎么设置微信钱包锁(苹果微信怎么设置置顶)

  • vivo怎么关掉5g用4g(vivo手机5g怎么关闭)

    vivo怎么关掉5g用4g(vivo手机5g怎么关闭)

  • vivos12拍照声音怎么关(vivo手机拍照声音)

    vivos12拍照声音怎么关(vivo手机拍照声音)

  • 电子书212ppi够用吗(电子书多少寸合适)

    电子书212ppi够用吗(电子书多少寸合适)

  • vivox30有隐藏功能吗(vivox30的隐藏功能)

    vivox30有隐藏功能吗(vivox30的隐藏功能)

  • qq为什么会被盗(qq为什么会被盗号发涩图)

    qq为什么会被盗(qq为什么会被盗号发涩图)

  • 手机qq音乐能倍速吗(手机qq音乐如何调音乐的倍数)

    手机qq音乐能倍速吗(手机qq音乐如何调音乐的倍数)

  • 怎么删除微信相册里面的图片和视频(怎么删除微信相册)

    怎么删除微信相册里面的图片和视频(怎么删除微信相册)

  • win10安装到一半黑屏(win10安装到一半进度就不动了)

    win10安装到一半黑屏(win10安装到一半进度就不动了)

  • 语音找手机怎么设置(语音找手机怎么设置小米)

    语音找手机怎么设置(语音找手机怎么设置小米)

  • 荣耀20怎么样隐藏应用(荣耀怎么样隐藏)

    荣耀20怎么样隐藏应用(荣耀怎么样隐藏)

  • 华为手机自带膜怎么撕掉(华为手机自带膜好难撕掉)

    华为手机自带膜怎么撕掉(华为手机自带膜好难撕掉)

  • AMDcpu后缀含义(amdcpu后缀字母含义)

    AMDcpu后缀含义(amdcpu后缀字母含义)

  • 全民k歌私密了为什么还有人可以收听(全民k歌私密了下载导出还能听吗)

    全民k歌私密了为什么还有人可以收听(全民k歌私密了下载导出还能听吗)

  • 微信群主自己退群了其他人怎么办(微信群主自己退群,群还存在吗)

    微信群主自己退群了其他人怎么办(微信群主自己退群,群还存在吗)

  • 防火墙技术是什么安全模型(防火墙技术是什么最重要的安全技术之一)

    防火墙技术是什么安全模型(防火墙技术是什么最重要的安全技术之一)

  • 一个手机可以下载几个微信(一个手机可以下两个快手吗)

    一个手机可以下载几个微信(一个手机可以下两个快手吗)

  • 苹果锁屏去掉手电筒(苹果锁屏去掉手机图标)

    苹果锁屏去掉手电筒(苹果锁屏去掉手机图标)

  • 苹果11下载东西一直获取不了怎么办(iphone 11 下载)

    苹果11下载东西一直获取不了怎么办(iphone 11 下载)

  • 苹果xs铃声怎么响一下就变小了(苹果xs铃声怎么更换)

    苹果xs铃声怎么响一下就变小了(苹果xs铃声怎么更换)

  • 3kw一小时几度电(3kw一小时几度电多少钱)

    3kw一小时几度电(3kw一小时几度电多少钱)

  • 华为20i手机怎么返回(华为20i手机怎么样)

    华为20i手机怎么返回(华为20i手机怎么样)

  • 京东哪里申请闪电退款(京东怎么申请闪电退款)

    京东哪里申请闪电退款(京东怎么申请闪电退款)

  • 用手机可以开网店吗(用手机开网店怎么开)

    用手机可以开网店吗(用手机开网店怎么开)

  • 税务安全组件初审流程
  • 给员工发礼品发什么礼品最实惠
  • 开现代服务发票有什么要求吗
  • 企业筹办期间发生的开办费会计分录
  • 索赔怎么开票
  • 第二季度的季初资产总额和季末资产总额怎么填
  • 报销费用可不可以开专票
  • 计提存货跌价准备是递延所得税资产吗
  • 培训学校预收学费要交税吗
  • 分公司往子公司投资如何做税务处理?
  • 从联营企业分回利润可以在税前扣除吗
  • 广告制作费有哪些项目
  • 制造型企业采购
  • 离职补偿金怎么计算
  • 所得税季报收入是全年吗
  • 固定资产明细账有哪些
  • 支付宝微信结算属于什么结算方式
  • 借给其他公司借款会计分录
  • 企业购入交易性金融资产支付的交易费用
  • 存货减值准备计提
  • 端午节给员工发福利说什么
  • 超过三年的坏帐损失税前扣除怎样规定?
  • 对外支付和对外转账
  • windows11怎么显示桌面图标
  • 自产自用产品的会计处理
  • 这张磁盘有写保护无法格式化
  • php面向对象是什么意思
  • 向国外个人支付的佣金是否缴纳个人所得税
  • win11设置共享文件夹
  • 完工产品成本怎么算
  • 增值税红字专用发票什么意思
  • 违约金列支
  • 增值税减免后按3%记提税款吗
  • 怎么做外资企业赚钱
  • 房地产土地使用税核减条件
  • 小微企业城建税及附加减免优惠
  • 持有待售资产是流动还是非流动
  • php curl_multi_init
  • 商品和服务税收分类编码表下载
  • phpcms v9用户手册
  • mysql的文件格式有哪些
  • python中Plotly Express是什么?
  • php生成器和迭代器理解
  • 销售熟食卤制品怎么做
  • 任意盈余公积金怎么计算
  • 开票金额和发票金额
  • 企业净利润怎么查询数据
  • 发工资时多打给员工的钱
  • 汇算清缴所得税的账务处理会计分录
  • 公司委托银行付款的账务处理
  • 资产负债表中各项目的期末余额
  • 外汇账户开立成功后,开户行应于
  • Linux下安装MySQL5.7.19问题小结
  • sqlserver数据库怎么导出
  • mysql未知的服务器主机
  • windows 10测试版
  • win7 组织
  • win7旗舰版系统激活码
  • freebsd怎么安装
  • upskill
  • centos编译器
  • 怎样让xp系统变得更加流畅
  • mac 活动监视器在哪里
  • windowsxp的主要特点是什么
  • ixapplet.exe - ixapplet是什么进程 有何作用
  • 安卓接入点
  • 铁嘴王指什么动物
  • windows批处理命令大全
  • cocos2dx3.2 xcode中资源路径设置问题
  • php和js的区别和联系
  • framelayout布局
  • 创业要看的书
  • shell函数返回多个值包含数组
  • 使用jquery实现的项目
  • python做脚本语言怎么用
  • Python Requests安装与简单运用
  • bootstrap需要学多久
  • python中set用法
  • 财税[2020]25号
  • 镇江市物业管理协会
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设