微前端介绍

提到微前端,稍微懂微前端的同学,可能会这样问,为什么不用iframe方案呢?

其实,如果不考虑体验问题,iframe方案几乎是最完美的微前端解决方案;

iframe最大的特性就是提供了浏览器原生的硬隔离方案(样式隔离、js隔离),但它最大的问题也在于此,隔离性无法突破,应用间上下文无法被共享。

iframe存在哪些问题?这里简单说说。

  • url不同步。
    • 浏览器刷新会重置(比如从列表页跳转到详情页、然后点击浏览器刷新按钮,会返回列表页,因为浏览器地址栏没有变化),导致iframe url状态丢失,浏览器的前进、后退按钮无法使用;
    • iframe和主页面共用一个浏览历史,iframe多次重定向,会导致浏览器的前进后退功能无法正常使用;
  • UI不同步,DOM结构不共享。弹框及遮罩层问题:只能在iframe范围内垂直水平居中,没有办法在整个页面垂直水平居中;
  • 全局上下文完全隔离,内存变量不共享。iframe 内外系统的通信、数据同步等需求,主应用的 cookie 要透传到根域名都不同的子应用中实现免登效果。
  • 慢。每次子应用进入都是一次浏览器上下文重建、资源重新加载的过程。

不同源的系统之间的通讯需要通过 postMessage,存在一定的安全性;
事件处理也是个问题,比如实现顶层菜单展开时,需要点击空白处收起,如果点到iframe则无法触发

相关推荐
ganshenml19 分钟前
【Web】证书(SSL/TLS)与域名之间的关系:完整、通俗、可落地的讲解
前端·网络协议·ssl
这是个栗子1 小时前
npm报错 : 无法加载文件 npm.ps1,因为在此系统上禁止运行脚本
前端·npm·node.js
HIT_Weston2 小时前
44、【Ubuntu】【Gitlab】拉出内网 Web 服务:http.server 分析(一)
前端·ubuntu·gitlab
华仔啊2 小时前
Vue3 如何实现图片懒加载?其实一个 Intersection Observer 就搞定了
前端·vue.js
JamesGosling6662 小时前
深入理解内容安全策略(CSP):原理、作用与实践指南
前端·浏览器
不要想太多2 小时前
前端进阶系列之《浏览器渲染原理》
前端
g***96903 小时前
Node.js npm 安装过程中 EBUSY 错误的分析与解决方案
前端·npm·node.js
七喜小伙儿3 小时前
第2节:趣谈FreeRTOS--打工人的日常
前端
我叫张小白。3 小时前
Vue3 响应式数据:让数据拥有“生命力“
前端·javascript·vue.js·vue3
laocooon5238578863 小时前
vue3 本文实现了一个Vue3折叠面板组件
开发语言·前端·javascript