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

  • 心灵间的幸福(心灵的幸福作文700字作文)

    心灵间的幸福(心灵的幸福作文700字作文)

  • 联通5g超级会员白银版怎么退订(联通5g超级会员白银版要钱吗)

    联通5g超级会员白银版怎么退订(联通5g超级会员白银版要钱吗)

  • 支付宝绑定信用卡可以扫码支付吗(支付宝绑定信用卡过期了怎么办)

    支付宝绑定信用卡可以扫码支付吗(支付宝绑定信用卡过期了怎么办)

  • 苹果电池显示维修(苹果电池显示维修还能充电吗)

    苹果电池显示维修(苹果电池显示维修还能充电吗)

  • 怎样冻结excel表指定的行列(怎样冻结excel表指定的行和列)

    怎样冻结excel表指定的行列(怎样冻结excel表指定的行和列)

  • 探探设置为忘不了的人(探探设置念念不忘的人是真的吗)

    探探设置为忘不了的人(探探设置念念不忘的人是真的吗)

  • 计算机ac和c的区别(计算机上的ac和c)

    计算机ac和c的区别(计算机上的ac和c)

  • 抖音本场点赞是什么(抖音本场点赞是收入吗)

    抖音本场点赞是什么(抖音本场点赞是收入吗)

  • 小米售后屏幕是否都为原装(小米售后屏幕是原装的吗)

    小米售后屏幕是否都为原装(小米售后屏幕是原装的吗)

  • 淘宝店可以自己亲自装修吗(淘宝店可以自己买自己的东西吗)

    淘宝店可以自己亲自装修吗(淘宝店可以自己买自己的东西吗)

  • 钉钉pc版是什么意思(钉钉PC版是什么意思)

    钉钉pc版是什么意思(钉钉PC版是什么意思)

  • 光驱是输入设备还是输出设备(光驱是存储器还是输入设备)

    光驱是输入设备还是输出设备(光驱是存储器还是输入设备)

  • 毒签名认证失败(为什么毒里面的实名认证过不了)

    毒签名认证失败(为什么毒里面的实名认证过不了)

  • 陌陌互相关注不能视频(陌陌互相关注不显示距离)

    陌陌互相关注不能视频(陌陌互相关注不显示距离)

  • 华为自带测网速在哪(华为自带测网速功能)

    华为自带测网速在哪(华为自带测网速功能)

  • 华为mate30有几个摄像头(华为mate30有几个版本的区别)

    华为mate30有几个摄像头(华为mate30有几个版本的区别)

  • 手机怎么查违章记录和扣分情况(不是本人的车手机怎么查违章)

    手机怎么查违章记录和扣分情况(不是本人的车手机怎么查违章)

  • 小米红外线有什么用(小米 红外线)

    小米红外线有什么用(小米 红外线)

  • 安卓手机怎么打印照片(安卓手机怎么打开定位)

    安卓手机怎么打印照片(安卓手机怎么打开定位)

  • 拼多多开团怎么开方法(拼多多开团怎么开的视频)

    拼多多开团怎么开方法(拼多多开团怎么开的视频)

  • QQ邮箱怎么发贺卡(qq邮箱邮件怎么发)

    QQ邮箱怎么发贺卡(qq邮箱邮件怎么发)

  • iphone怎样防止误删应用app(苹果手机怎么防止误碰)

    iphone怎样防止误删应用app(苹果手机怎么防止误碰)

  • 苹果8p基带怎么查看(苹果8p基带位置)

    苹果8p基带怎么查看(苹果8p基带位置)

  • css字体加粗(dw怎么在css里字体加粗)(css字体加粗怎么弄)

    css字体加粗(dw怎么在css里字体加粗)(css字体加粗怎么弄)

  • 养鸡增值税税率是多少
  • 网上报税怎么报啊
  • 分派现金股利需要缴税吗
  • 救援车拉货交警查吗?
  • 发票备注没写
  • 凭发票还是结算票据
  • 金融利息是什么意思
  • 电子申报率较差的原因
  • 没有及时取得发票可以入成本么
  • 员工个人无息借款违法吗
  • 收到第三方利息会计分录
  • 委托加工农产品的扣除率
  • 担保预计负债要如何做账?
  • 物流公司货物丢失不赔偿怎么处理
  • 逆流交易固定资产折旧实现,为什么按差额
  • 住宿费进项发票账务处理
  • 个人代开普通发票需要出税费吗?
  • 城建税漏报怎么办
  • 营改增开始试点到普及的行业
  • 洗衣店每个月水电费多少钱
  • 自然灾害造成的存货净损失计入什么科目
  • 企业财务内部控制的主要内容有哪些
  • 收到老板的钱会计分录
  • 社保已申报未缴费可以减员吗
  • 使用时间长但金币不见了
  • 企业所得税投资收益纳税调整
  • 简易计税项目进项
  • 周转材料购置费属于材料费吗
  • 现金日记账期初余额怎么登账
  • 子公司代总公司付款
  • PHP:oci_bind_by_name()的用法_Oracle函数
  • 可转换债券的特点有哪些?
  • 苹果电脑字体文件怎么拖出来
  • 增值税发票支票号
  • 三万个字多久写完
  • 股东分红应该在哪个科目
  • web前端基础教程
  • 模型参数是什么意思
  • curl命令上传文件到服务器
  • 应付职工薪酬包括哪些二级科目
  • 实发工资总额怎么算
  • mysql union or
  • 进销存的原理
  • 电子发票额度余额怎么查
  • 个人独资企业的
  • 其他货币资金期末有余额吗
  • ibps对公提回贷记有什么影响
  • 利润表中的资产处置收益应该计入营业利润还是利润总额
  • 外贸会计账务处理实务
  • 工资标准表
  • 收到发票应如何处理
  • 外购货物用于促销的账务处理
  • 转出未交增值税和未交增值税区别
  • 未付工资挂什么科目
  • 银行承兑到期之前怎么办
  • 差额事业单位的工资是由财政开支吗
  • 长期股权投资会计实训心得
  • 低值易耗的管理制度
  • 企业因固定资产破产
  • 从农民手里租用土地用于科研要开发票吗
  • 在途物资和材料采购的区别
  • 不含税价换算成含税价怎么算
  • 会计从业资格证取消了吗
  • mysql数据查询慢
  • centos的版本有哪些
  • ubuntu中怎么卸载软件
  • storm run off
  • win10更新预览版
  • windowsserver2008修改远程端口
  • cmd命令基础
  • python 对象函数
  • jquery读写文件
  • shell脚本数组的用法
  • shell脚本windows
  • python爬虫模拟登录亚马逊
  • 用yum安装samba
  • 爱信诺开票系统怎么安装
  • 电子税务局网页版
  • 铁路检察院和普检哪个好
  • 草原补偿标准
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设