vue 使用iframe标签切换不同项目,实现步骤(互相嵌套,高度不适应(底部出现白条-随着切换越来越大)传值取值(免登录),内容空白缓存问题)

前言

  • 最近在开发中,由于是合作开发。双方已经有自己的前后端代码,最终需要整合代码上线测试

  • 由于模块功能不同,双方ui并没有提前统一设计风格,并且已经开发完毕。

  • 前后端如果直接合并到对方项目(前端-有各种冲突-后端鉴权-业务场景不一样)导致.......

  • 后来最好的解决办法就是,通过iframe标签带参数来回切换对方项目

实现步骤

1.首先思路明确(文档能力)- 双方前端项目合并可能出现问题

  • 前端工程已经分离社会端,监管端(支队-总队-服务端),登录方式不一(鉴权方式不一)

  • 整体布局风格不统一,代码规范不统一,公共组件不统一,合并之后需要大量时间修改调整细节

  • 命名冲突,合并代码之后可能应为组件名,路由名,文件资源名,类名重名,导致代码报错需要修改多处

  • 前端用户体系框架业务代码已经完善,合并之后冲突。导致业务逻辑代码需要大量时间重构调试

  • 前端工程分开独立部署,可以通过代码层面区分社会端,监管端(支队-总队-服务端)。合并之后无法区分

  • 前端全局处理机制不一样,合并之后冲突。导致统一处理失效。(全局状态码-统一错误处理,机制处理)

  • 前端第三方库版本不一,合并之后。可能因为部分库版本对不上导致部分api,功能失效,出现兼容性问题

2.代码实现

// HTML代码
<divclass="app-haiyun"v-if="sirenindex == 2 "><iframe:src="iframeUrl"style="width: 100%; height: 100%; border: 0"></iframe></div>// 传递地址访问别人项目-别人项目接受参数免登录-浏览器缓存问题
// 3个参数
// 第一个参数当前时间戳-防止第二个项目有默认路径参数导致参数取不到-防止iframe请求参数一样导致浏览器触发缓存导致boday加载不出来(第二个项目)
// 第二个参数第二个项目token-拿来做免登录处理
// 第三个参数业务参数-可以不要
// 获取token
let Token = getToken()
​
let time = new Date().getTime()
// 路径传参-项目二地址+参数
// this.iframeUrl = `http://192.168.2.23:3000?time=${time}&validToken=${haiyunToken}&menuType=2`
// 开启iframe标签开关
this.sirenindex = 2
​
// 第二个项目-接受参数(可以在指定页面接受,也可直接写在登录页(因为导航守卫会把没token打回登录页))mounted () {// 参数处理// 解析URL中的查询字符串console.log('window.location', window.location)
​console.log('window.location.search',decodeURIComponent(window.location.search))const urlParams = new URLSearchParams(decodeURIComponent(window.location.search))console.log("urlParams", urlParams);console.log("validToken", urlParams.get("validToken"));console.log("menuType", urlParams.get("menuType"));console.log("time", urlParams.get("time"));}
​
​
​
// 样式-整屏切换-高度100vh 防止底部出现白条-导致来回切换项目时底部白条空隙越来越大
.app-haiyun {position: fixed;top: 0;left: 0;z-index: 99999;width: 100vw;height: 100vh;
}

细节优化

1.须知

  • 首相2个项目是假合并,让用户感觉不出来。所以2个项目的用户数据数据和token有效期是一样的

  • 第一个项目通过iframe标签跳转到第二个项目需要登录,再通过刷新或者返回时第一个项目不需要登录

  • 如果是通过2个按钮来切换项目记得使用浏览器缓存,因为在第二个项目刷新时默认会返回第一个项目

  • 切换时我们打开浏览器缓存可以看到是2个地址缓存,隔离开来,并且在请求栏可以看到2个项目请求

2.高度适应问题-底部出现白条,随着iframe来回切换项目导致底部白色间隙越来越大,项目布局失衡

解决:在iframe外面套一层div-设置100vw,100vh。iframe标签100%,边框为0

3.2个项目免登录问题

  • 首相我们在第一个项目传递token时最好是在iframe地址第一个参数加上time=等于当前时间戳,再拼接token

    原因1:因为iframe标签获取项目也是在发送请求,短时间平凡切换可能会参数一样(token没变)当浏览器发现这个请求一直在请求并且参数一样,可能会触发浏览器缓存机制,导致iframe标签不在加载,某个项目boday加载不出来导致白屏

    原因2:一般项目在没有token,或者token过期时可能会带参数返回登录页,iframe也带参数,导致2个参数2个问号,导致第二个项目在登录页参数取不到。

  • 如果第二个项目是别人的,免登录问题不用管,传递token让他们处理即可

  • 如果2个项目都是自己-我们也可以解决

    解决:在login页面接受第一个项目token,解析出用户账号密码直接前端走原来页面方法,但是注意要使用遮罩层,避免用户看到2个登录页面,察觉到是2个项目


总结:

经过这一趟流程下来相信你也对 vue 使用iframe标签切换不同项目,实现步骤(互相嵌套,高度不适应(底部出现白条-随着切换越来越大)传值取值(免登录),内容空白缓存问题) 有了初步的深刻印象,但在实际开发中我 们遇到的情况肯定是不一样的,所以我们要理解它的原理,万变不离其宗。加油,打工人!

有什么不足的地方请大家指出谢谢 -- 風过无痕

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/679141.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

创建菜单与游戏页面

bootstrap地址 Bootstrap v5 中文文档 Bootstrap 是全球最受欢迎的 HTML、CSS 和 JS 前端工具库。 | Bootstrap 中文网 (bootcss.com) 创建导航栏组件 web--src--components--NavBar.vue <!-- html --> <template><nav class"navbar navbar-expand-lg n…

机器学习:Softmax介绍及代码实现

Softmax原理 Softmax函数用于将分类结果归一化&#xff0c;形成一个概率分布。作用类似于二分类中的Sigmoid函数。 对于一个k维向量z&#xff0c;我们想把这个结果转换为一个k个类别的概率分布p(z)。softmax可以用于实现上述结果&#xff0c;具体计算公式为&#xff1a; 对于…

GO语言笔记4-标识符、关键字与运算符

标识符 什么是标识符 变量名、方法名等我们起的名字都是标识符 标识符定义规则 字母、数字、下划线组成不可以数字开头&#xff0c;严格区分大小写&#xff0c;不能带有空格&#xff0c;不可以是go的关键字不能单独使用 下划线&#xff0c;因为下划线在GO中是一个特殊标识符&…

2024刘谦春晚第二个扑克牌魔术

前言 就是刚才看春晚感觉这个很神奇&#xff0c;虽然第一个咱模仿不过来&#xff0c;第二个全国人民这么多人&#xff0c;包括全场观众都有成功&#xff0c;这肯定是不需要什么技术&#xff0c;那我觉得这个肯定就是数学了&#xff0c;于是我就胡乱分析一通。 正文 首先准备…

Pandas to_csv() - 将 DataFrame 转换为 CSV

Pandas DataFrame to_csv() 函数将 DataFrame 转换为 CSV 数据。我们可以传递一个文件对象来将 CSV 数据写入文件中。否则&#xff0c;CSV 数据将以字符串格式返回。 Pandas DataFrame to_csv() 语法 DataFrame to_csv() 函数的语法是&#xff1a; def to_csv(self,path_or_…

ElasticSearch级查询Query DSL下

目录 全文检索 match query匹配查询 multi_match query 多字段查询 match_phrase query短语查询 query_string query simple_query_string bool query布尔查询 highlight高亮 自定义高亮html标签 多字段高亮 全文检索 全文检索查询&#xff08;Full Text Queries&…

【蓝桥杯冲冲冲】k 短路 / [SDOI2010] 魔法猪学院

蓝桥杯备赛 | 洛谷做题打卡day33 文章目录 蓝桥杯备赛 | 洛谷做题打卡day33题目背景题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 提示数据规模数据更新日志 题解代码我的一些话 【模板】k 短路 / [SDOI2010] 魔法猪学院 题目背景 注&#xff1a;对于 k k k 短路问…

正则可视化工具:学习和编写正则表达式的利器

引言 正则表达式是一种强大的文本匹配和处理工具&#xff0c;但对于初学者和非专业开发者来说&#xff0c;编写和理解正则表达式可能是一项具有挑战性的任务。为了帮助人们更好地学习和编写正则表达式&#xff0c;正则可视化工具应运而生。本文将探讨正则可视化工具的优点&…

ChatGPT在国际中文教育领域引起的变革与挑战

随着ChatGPT这一先进的自然语言处理模型的出现&#xff0c;教学、学习、测评和辅导的传统方式正在面临可能的重塑。她是否会影响中文教育的未来方向&#xff0c;甚至取代中文教师的角色&#xff0c;成为了许多人热议的话题。本文旨在探讨ChatGPT与中文测评之间的联系&#xff0…

并行计算导论 笔记 1

目录 并行编程平台隐式并行超标量执行/指令流水线超长指令字处理器 VLIW 内存性能系统的局限避免内存延迟的方法 并行计算平台控制结构通信模型共享地址空间平台消息传递平台对比 物理组织理想并行计算机并行计算机互联网络网络拓朴结构基于总线的网络交叉开关网络多级网络全连…

leaflet 显示自己geoserver发布的中国地图

安装vscode 安装 通义灵码 问题&#xff1a; 用leaflet显示一个wms地图 修改下代码&#xff0c;结果如下&#xff1a; 例子代码 <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8"><meta name"viewport&q…

自然语言处理(NLP)—— 基本概念

自然语言处理&#xff08;Natural Language Processing&#xff0c;简称NLP&#xff09;是人工智能和语言学领域的一个分支&#xff0c;它涉及到计算机和人类&#xff08;自然&#xff09;语言之间的相互作用。它的主要目标是让计算机能够理解、解释和生成人类语言的数据。NLP结…

Debezium发布历史123

原文地址&#xff1a; https://debezium.io/blog/2022/06/02/debezium-1-9-3-final-released/ 欢迎关注留言&#xff0c;我是收集整理小能手&#xff0c;工具翻译&#xff0c;仅供参考&#xff0c;笔芯笔芯. Debezium 1.9.3.Final Released June 2, 2022 by Chris Cranford r…

极狐GitLab 与钉钉的集成实践

DingTalk OAuth 2.0 OmniAuth provider * 引入于 14.5 版本。 您可以使用您的钉钉账号登录极狐GitLab。 登录钉钉开放平台&#xff0c;创建应用。钉钉会生成一个客户端 ID 和密钥供您使用。 登录钉钉开放平台。 在顶部栏上&#xff0c;选择 应用程序开发 > 企业内部开发&am…

【EAI 015】CLIPort: What and Where Pathways for Robotic Manipulation

论文标题&#xff1a;CLIPort: What and Where Pathways for Robotic Manipulation 论文作者&#xff1a;Mohit Shridhar1, Lucas Manuelli, Dieter Fox1 作者单位&#xff1a;University of Washington, NVIDIA 论文原文&#xff1a;https://arxiv.org/abs/2109.12098 论文出处…

【数据结构】链式队列解析(C语言版)

数据结构——链队列解析过程和简单代码实现&#xff1a; 一、简单概念&#xff1a; 动图展示&#xff1a; (1)入队&#xff1a;(2)出队&#xff1a; 二、顺序队列&#xff1a; 思路步奏&#xff1a; &#xff08;1&#xff09;入队操作&#xff1a;&#xff08;2&#xff09;出…

组合模式:简化复杂结构的设计艺术

组合模式&#xff1a;简化复杂结构的设计艺术 在软件开发的世界里&#xff0c;设计模式是帮助我们解决常见问题的一系列最佳实践。其中&#xff0c;组合模式以其独特的方式处理对象的组合&#xff0c;使得单个对象和组合对象的管理变得更加简单和直观。本文将深入探讨组合模式…

《统计学简易速速上手小册》第6章:多变量数据分析(2024 最新版)

文章目录 6.1 主成分分析&#xff08;PCA&#xff09;6.1.1 基础知识6.1.2 主要案例&#xff1a;客户细分6.1.3 拓展案例 1&#xff1a;面部识别6.1.4 拓展案例 2&#xff1a;基因数据分析 6.2 聚类分析6.2.1 基础知识6.2.2 主要案例&#xff1a;市场细分6.2.3 拓展案例 1&…

第2讲投票系统后端架构搭建

创建项目时&#xff0c;随机选择一个&#xff0c;后面会生成配置properties文件 生成文件 maven-3.3.3 设置阿里云镜像 <?xml version"1.0" encoding"UTF-8"?><!-- Licensed to the Apache Software Foundation (ASF) under one or more cont…

【Python】Mac 本地部署 stable-diffusion

其实要在本地部署 stable-diffusion 不难&#xff0c;只要有“魔法”一切都水到渠成&#xff0c;如下图&#xff1a; (base) MacBook-Pro python % git clone https://github.com/AUTOMATIC1111/stable-diffusion-webui Cloning into stable-diffusion-webui... remote: Enu…