iframe框架及优缺点
iframe框架及优缺点
HTML5
不再支持使用frame
,关于frame
与iframe
的区别,可以参阅 iframe与frame的区别
基本使用
src
:规定在iframe
中显示的文档的URL
。frameborder
:规定是否显示框架周围的边框。scrolling
:规定是否在 iframe 中显示滚动条。width
:规定iframe
的宽度,建议使用CSS
替代。height
:规定iframe
的高度,建议使用CSS
替代。sandbox
:启用一系列对iframe
中内容的额外限制。marginwidth
:定义iframe
的左侧和右侧的边距。marginheight
:定义iframe
的顶部和底部的边距。srcdoc
:规定在iframe
中显示的页面的HTML
内容。align
:规定如何根据周围的元素来对齐此框架,建议使用样式替代。
使用场景
加载其他域的网页
<iframe>
是允许跨域请求资源的,但是不能够修改,由此可以在网页中嵌套其他网页,如需要跨域通信的话,需要考虑document.domain
、window.name
、window.postMessage
。
典型系统结构
典型的系统结构,左侧是功能树,上部为个人信息,右侧就是实际功能,使用iframe
将功能单独分离出来,当然也可以使用vue
和react
进行实现。
实现Ajax
可以使用iframe
进行实现异步请求发送,来模拟Ajax
的请求操作,Ajax
的异步请求完成操作为XHR.readyState === 4
执行callback
,iframe
使用iframe.onload
执行callback
,还可以实现一个轮询长连接。
加载广告
广告是与原文无关的,假如硬编码进去,会造成网页布局的紊乱,而且这样势必需要引入额外的css
和js
文件,极大的降低了网页的安全性,使用iframe
便可以解决这些问题。
提交表单
可以使用iframe
提交表单来避免整个页面的刷新,还可以实现无刷新文件上传的操作。
优缺点
优点
- 可以跨域请求其他网站,并将网站完整展示出来
- 典型系统结构可以提高代码的复用性
- 创建一个全新的独立的宿主环境,可以隔离或者访问原生接口及对象
- 模块分离,若多个页面引用同一个
iframe
,则便于修改操作 - 实现广告展示的一个解决方案
- 若需要刷新
iframe
则只需要刷新框架内,不需要刷新整个页面
缺点
iframes
阻塞页面加载,影响网页加载速度,iframe
加载完毕后才会触发window.onload
事件,动态设置src
可解决这个问题。- 加载了新页面,增加了
css
与js
文件的请求,即额外增加了HTTP
请求,增加了服务器负担。 - 有时
iframe
由于页面挤占空间的原因出现滚动条,造成布局混乱。 - 不利于
SEO
,搜索引擎的爬虫无法解读iframe
的页面。 - 有些小型的移动设备如手机等无法完全显示框架,兼容性较差。
iframe
与主页面是共享链接池的,若iframe
加载时用光了链接池,则会造成主页面加载阻塞。
参考
https://www.zhihu.com/question/20653055
https://www.cnblogs.com/hq233/p/9849939.html
https://blog.csdn.net/baxiadsy_csdn/article/details/86245809
iframe框架及优缺点的更多相关文章
- ASP.NET 页面禁止被 iframe 框架引用
两个站点: a.sample.com b.sample.com a.sample.com 站点中的一段示例 JS 代码: var iframe = document.createElement(&qu ...
- 当session过期后自动跳转到登陆页而且会跳出iframe框架
写项目时在重定向后一直存在一个问题就是重定向后登陆页面会出现在跳出的子框架里.
- session失效后,登录页面嵌入iframe框架
在登录页面的onload方法中加入以下代码解决: //防止登录页面嵌入iframe框架 if (top.location != self.location){ top.location=self.lo ...
- javascript获取iframe框架中页面document对象,获取子页面里面的内容,iframe获取父页面的元素,
javascript获取iframe框架中,加载的页面document对象 因为浏览器安全限制,对跨域访问的页面,其document对象无法读取.设置属性 function getDocument(i ...
- 动端逐渐出了许多的移动端的框架,比如Sencha Touch、JQTouch、Jquery-moblie、jqMobi等等。这些框架都有优缺点,不同的框架应用在不同的项目中。现简单阐述一下各框架的优缺点:
移动前端工作的那些事---前端制作之微信小技巧篇 (2013-11-15 15:20) 转载▼ 标签: it css3/javascript html5 webapp 手机网站搭建 分类: 前端制 ...
- js实现网页防止被iframe框架嵌套及几种location.href的区别
首先我们了解一下几种location.href的区别简单的说:几种location.href的区别js实现网页被iframe框架功能,感兴趣的朋友可以了解下 首先我们了解一下:window.locat ...
- javascript_获取iframe框架中元素节点的属性值
1. DOM:文档对象模型 [window 对象] 它是一个顶层对象,而不是另一个对象的属性即浏览器的窗口. [document 对象] 该对象是window和frames对象的一个属性,是显示于窗口 ...
- iframe框架自适应高度 uncanght SecurityError: Blocked a frame with origin "null" from accessing a frame ....
来源于crm项目的contact/edit.html 一.背景是这样的 最近在做crm系统的前端页面,有一个页面呢,点击“查看全部信息”时会弹出,这个弹窗里面又有分页导航,分页不是使用ajax 异步刷 ...
- 在Iframe框架下如何跳转到登录界面
在Iframe框架下跳转到登录界面总会跳到子界面中,类似于下图 试用Respon.Redirect()不行, 用Js函数,但我跳转代码都是写在cs文件中的,用Respose.write(),js函数根 ...
随机推荐
- Java volatile修饰字段
一.关键字volatile修饰字段: 使用特殊域变量(volatile)实现线程同步 volatile:不稳定的:反复无常的:易挥发的: 1.volatile关键字为域变量的访问提供了一种免锁机制, ...
- python socket粘包及实例
1.在linux中经常出现粘包的出现(因为两个send近靠着,造成接受到的数据是在一起的.)解决方法: 在服务端两send的中间中再添加一个recv(),客户端添加一个send(),服务端收到信息确认 ...
- js中判断为false的情况
document.write((new Boolean())+"<br />"); document.write((new Boolean(" ...
- 查漏补缺:Linux进程与线程的区别
1.概念的区别 进程:是具有独立功能的程序在一个数据集合上运行的过程,是系统进行资源分配的基本单位,也是调度运行的基本单位.一个进程中可以包含多个线程. 线程:是进程的一个实体,是CPU调度和分派的基 ...
- 自动贩卖机VS无人门店:谁是真正的零售新风口?
原本在线上不断发力,让实体店几乎凋敝的电商,却忽然对线下兴趣大增.阿里疯狂入股.收购线下商超:京东要在全国范围内开设百万家便利店,仅在农村就将开设50万家--这一股浪潮,或将直接改变整个百货零售 ...
- Job for network.service failed because the control process exited with error code问题
Job for network.service failed because the control process exited with error code问题 因为是克隆的,所以需要重新修改静 ...
- C++走向远洋——50(Time类中的运算符重载、一目,二目比较运算符、二目赋值运算符、二目加减法运算符)
*/ * Copyright (c) 2016,烟台大学计算机与控制工程学院 * All rights reserved. * 文件名:text.cpp * 作者:常轩 * 微信公众号:Worldhe ...
- PyCharm使用技巧及常用快捷键
Ctrl + Shift + F--------------------------------------------->>>>>>>高级查找 Ctrl + ...
- [面试专题]Web缓存详解
Web缓存详解 标签(空格分隔): 缓存 缓存之于性能优化 请求更快:通过将内容缓存在本地浏览器或距离最近的缓存服务器(如CDN),在不影响网站交互的前提下可以大大加快网站加载速度. 降低服务器压力: ...
- 基于sklearn的metrics库的常用有监督模型评估指标学习
一.分类评估指标 准确率(最直白的指标)缺点:受采样影响极大,比如100个样本中有99个为正例,所以即使模型很无脑地预测全部样本为正例,依然有99%的正确率适用范围:二分类(准确率):二分类.多分类( ...