微前端实现方案之iframe

计算机软件开发 2024-10-9 01:44:45 210 0 来自 中国
微前端是近来几年火起来的概念,iframe是早期实现微前端的抱负方案,而现在有了别的的方案,比如qianduan框架,single-spa,以及webpack5带来的联邦模块方案。但是每一个方案都有其优缺点,感爱好的可以去实践一下。
1、项目创建

创建3个项目,一个基座项目project_base,2个子项目project_a和project_b项目。并在各个项目安装好依赖(本项目基于vue搭建)。

2、项目根本结构

在基座项目里创建一个路由文件如iframe.vue,我们在这个文件里完成project_a,project_b等子项目标访问。

2.png 3、项目路由

每个项目分别管理自己的路由。但是需要在基座项目路由里注册管理。待访问的时间实时监听路由信息判断访问的是哪个项目。
3.png 4、项目需要办理的一些题目。

iframe的使用有很多坑,有些好办理,有些只能忍受。比如:
1、项目之间的通讯
2、iframe的弹窗及遮罩层题目
3、iframe里的全屏题目
4、组件复用题目
5、欣赏器的前进退却题目
5、项目通讯题目

只能使用postMessage方法来完成基座项目和子项目之间的通讯。
6、iframe里的全屏题目

全屏方案,原生方法使用的是 Element.requestFullscreen(),插件:vue-fullscreen。当页面在 iframe 内里时,全屏会报错,且 dom 结构繁芜。
办理方案:iframe 标签设置 allow="fullscreen" 属性即可
6、localStorage共享题目

跨域时间localStorage是无法共享数据的。我们可以接纳:cross-storage插件
7、公共组件复用

公共组件可以单独提出来放到一个单独的项目里,这里是components项目,在components项目把公共组件全部暴袒露来供别的项目安装使用,也就是说主项目和子项目可以选择性安装需要的组件。参考文章:多个前端项目中公共组件使用方案(npm包方式) 。如下图,在project_base项目里安装了整个components项目里的组件。


8、欣赏器前进/退却题目

iframe 和主页面共用一个欣赏汗青,iframe 会影响页面的前进退却。而且 iframe 页面革新会重置,因为欣赏器的地点栏没有厘革,iframe 的 src 也没有厘革。这个题目暂时也没办理,还需研究。
9、项目地点

完整的项目请访问:github地点,假如对你点用处,可以点个start。
您需要登录后才可以回帖 登录 | 立即注册

Powered by CangBaoKu v1.0 小黑屋藏宝库It社区( 冀ICP备14008649号 )

GMT+8, 2025-1-19 10:39, Processed in 0.180434 second(s), 35 queries.© 2003-2025 cbk Team.

快速回复 返回顶部 返回列表