当被问到你使用过iframe吗?有哪些优点和缺点?

简介: 当被问到你使用过iframe吗?有哪些优点和缺点?

前言

之前做需求遇到过这样的场景,两个不同的平台,其中一个平台需要使用另一个平台的某个页面,在没有用微前端和独立封装组件库的时候。就想到了使用iframe,直接将另一个页面嵌入到需要的页面里面。2即使是不同源的也没问题。

什么是iframe

介绍

前端的iframe(内联框架)是一种HTML元素,它允许你在网页中嵌入另一个网页或文档。通过使用iframe,你可以在一个网页中显示来自不同源或同一源的内容,这对于嵌入地图、视频、广告或其他外部资源非常有用。

使用

<iframe>(内联框架)在前端开发中有多种作用和使用场景。以下是一些常见的用途和场景:

  1. 嵌入外部网页:最常见的用途是在你的网页中嵌入其他网站的内容。这可以用于显示其他网站的页面、地图、社交媒体小部件、外部应用程序或其他在线资源。
<iframe src="https://www.example.com"></iframe>
  1. 嵌入本地网页:你可以使用iframe来嵌入同一网站内的其他页面或本地HTML文件。这对于在一个页面中显示多个内容块或小部件非常有用。
<iframe src="other-page.html"></iframe>
  1. 视频和音频嵌入:你可以使用iframe来嵌入在线视频和音频播放器,例如YouTube、Vimeo、SoundCloud等。
<iframe src="https://www.youtube.com/embed/VIDEO_ID"></iframe>
  1. 广告显示:广告网络通常使用iframe来嵌入广告,以便在多个网站上显示广告内容。
<iframe src="https://advertisements.com/advert"></iframe>
  1. 安全隔离: 有时,你可能需要在网页中加载来自不同源的内容,但由于同源策略的限制,使用iframe可以在一定程度上实现安全隔离。
  2. 跨域通信: 使用postMessage API,你可以在不同的iframe之间进行跨域通信,以实现数据传输和事件处理。
  3. 多语言支持: 在多语言网站中,你可以使用iframe来嵌入不同语言版本的内容,以便用户切换语言。
  4. 动态加载内容: 通过JavaScript,你可以动态创建和加载iframe,以便根据用户的交互或其他条件加载不同的内容。

iframe页面如何接收父级页面的参数

为了更灵活的使用iframe嵌套,iframe页面接收父级页面的参数,可以针对不同情况展示不同的内容。有几种方法可以实现这种参数传递:

  1. URL查询参数:你可以将参数作为查询字符串附加到iframe的src属性中。iframe页面可以通过JavaScript来解析URL中的查询参数并使用它们。父级页面:
<iframe src="iframe.html?param1=value1¶m2=value2"></iframe>
  1. iframe页面:
// 解析查询参数
var urlParams = new URLSearchParams(window.location.search);
var param1 = urlParams.get('param1');
var param2 = urlParams.get('param2');

2.postMessage API: 使用postMessage API,你可以将参数作为消息发送给iframe页面。这提供了更灵活的方式来传递数据,包括跨域通信。

父级页面:

var iframe = document.getElementById('myIframe');
iframe.contentWindow.postMessage({ param1: 'value1', param2: 'value2' }, 'https://example.com');


iframe页面:

window.addEventListener('message', function(event) {
  if (event.origin === 'https://example.com') {
    // 处理从父级页面发送的消息
    var data = event.data;
    var param1 = data.param1;
    var param2 = data.param2;
  }
});

3.Cookie: 如果iframe和父级页面位于同一域名下,你可以使用Cookie来在它们之间共享数据。请注意,这只适用于同一域名的情况。

父级页面:


document.cookie = 'param1=value1; path=/';
document.cookie = 'param2=value2; path=/';

iframe页面:

// 从Cookie中读取参数
var param1 = getCookie('param1');
var param2 = getCookie('param2');

优点与缺点

优点:

  1. 内容嵌入: 最大的优点之一是能够在一个网页中嵌入其他网页或内容。这使得可以轻松地在你的网站上显示来自不同源的内容,如外部网站、媒体、广告等。
  2. 代码分离: 使用iframe,你可以将网站的不同部分拆分为独立的HTML文档,这有助于代码的分离和维护。
  3. 安全性隔离: 由于浏览器的同源策略,iframe可以提供安全性隔离,防止来自嵌入内容的恶意代码影响主页面。
  4. 多语言支持: 可以使用iframe来加载不同语言版本的内容,以满足多语言网站的需求。
  5. 跨域通信: 通过postMessage API,你可以在不同的iframe之间进行跨域通信,实现数据传输和事件处理。

缺点:

  1. 性能开销: 使用大量的iframe可能会导致性能问题,因为每个iframe都需要加载和渲染,增加了页面的复杂性。
  2. SEO问题: 搜索引擎爬虫可能不会正确解释和索引iframe中的内容,这可能会影响到网站的搜索引擎排名。
  3. 访问性问题: 屏幕阅读器等辅助技术可能难以处理iframe中的内容,从而影响到网站的可访问性。
  4. 页面加载时间: 如果你嵌入的内容来自慢速服务器或需要长时间加载,可能会延长整个页面的加载时间。
  5. 外观一致性: 嵌套的iframe可能会导致外观和样式的不一致性,因为每个iframe都可以有自己的CSS规则。
  6. 用户体验问题: 如果不妥善处理,iframe可能会导致用户体验问题,如滚动问题、点击穿透等。
  7. 安全风险: 如果不小心,iframe可以用于点击劫持(clickjacking)等安全漏洞,因此必须小心处理安全性问题。
目录
相关文章
|
JavaScript
【登录界面】vue、element-ui登录界面模板
这里总结一个用vue、element-ui写的登录界面,为以后复制粘贴备用
2196 0
【登录界面】vue、element-ui登录界面模板
|
存储 算法 NoSQL
还分不清 Cookie、Session、Token、JWT?看这一篇就够了
Cookie、Session、Token 和 JWT(JSON Web Token)都是用于在网络应用中进行身份验证和状态管理的机制。虽然它们有一些相似之处,但在实际应用中有着不同的作用和特点,接下来就让我们一起看看吧,本文转载至http://juejin.im/post/5e055d9ef265da33997a42cc
49543 13
|
SQL 前端开发 JavaScript
基于java+springboot的求职招聘网站-求职招聘管理系统
该系统是基于java+springboot开发的求职招聘网站、网上招聘管理系统、网上人才招聘系统、毕业生求职招聘系统、大学生求职招聘系统、校园招聘系统、企业招聘系统。是给师弟开发的毕业设计。
562 1
|
机器学习/深度学习 存储 算法
时序数据特征工程浅析
内容摘要特征工程是指将原始数据标记处理为价值密度更高,更容易解释目标问题的工程化过程,在面向大量原始采集的数据集统计分析,尤其是对于高通量持续采集、且价值密度较低的时序数据更是如此。时序数据特征工程则是指利用有效方法,将原始时序数据转化为带有含义分类标签的序列数据片段或特征数值,例如,我们可以将指定时间窗口序列数据标识为特定异常关联数据,并保留平均、最大、最小值作为该序列的特征值。这样我们就可以围
4377 0
时序数据特征工程浅析
|
网络协议
通俗易懂理解三次握手、四次挥手(TCP)
这篇文章用通俗的语言解释了TCP协议中的三次握手和四次挥手过程,通过比喻和详细的状态变化描述,帮助读者理解建立和断开连接的原理和原因。
通俗易懂理解三次握手、四次挥手(TCP)
|
移动开发 资源调度 JavaScript
Vue2使用触摸滑动插件(Swiper)
这篇文章介绍了在Vue 3框架中如何使用Swiper插件来创建不同类型的触摸滑动组件,包括轮播图、淡入淡出效果和走马灯效果,并提供了详细的配置选项和使用示例。
1279 1
Vue2使用触摸滑动插件(Swiper)
|
监控 前端开发 测试技术
如何使用 Tree Shaking 进行代码优化
Tree Shaking 是一种通过去除未使用的代码来优化项目打包体积的技术,在现代前端开发中被广泛应用
|
JSON 前端开发 JavaScript
不会webpack的前端可能是捡来的,万字总结webpack的超入门核心知识
该文章提供了Webpack的基础入门指南,涵盖安装配置、基本使用、加载器(Loaders)、插件(Plugins)的应用,以及如何通过Webpack优化前端项目的打包构建流程。
不会webpack的前端可能是捡来的,万字总结webpack的超入门核心知识
Element UI 上传文件 el-upload —— 手动上传文件,限制上传文件数量,文件类型校验等
Element UI 上传文件 el-upload —— 手动上传文件,限制上传文件数量,文件类型校验等
4756 0
|
监控 安全 Java
构建Java版监控系统:从入门到精通
构建Java版监控系统:从入门到精通
229 1

热门文章

最新文章