iframe 自适应高度、父子页面传值、回调
总结一下最近用iframe遇到的问题与解决办法:
结构:主页面main.html,里面套用iframe。iframe不能出现滚动条,自适应子页面高度。内容多了滚动条是main.html页面的。
1. 主页面自适应iframe页面的高度
这个问题网上的大部分都是自适应静态iframe页面,而且代码较多,对于动态变化的iframe页面,解决的办法少。
我的解决办法很粗狂:获取iframe页面的高度,在设置父页面iframe标签的高度。兼容性我相信都没问题吧。
iframe页面:
setParentHeight()
function setParentHeight(){
var nowHei=$('body').height();//获取当前页面高度
parent.setIframeHeight(nowHei);//调用父页面设置高度函数
}
主页面:记得设置iframe scrolling="no"属性,这样iframe就没滚动条了。无边框是设置 frameborder="0"
//设置iframe高度
function setIframeHeight(hei){
$('#m-iframe').height(hei);//m-iframe是ifram的id
}
(1) 这样的处理方式很简单,缺点就是iframe页面高度动态变化的时候,比如加载更多,这时还是需要调用 setParentHeight 函数来再次设置父页面iframe标签的高度。
2. 主页面与iframe页面传值和回调。
(1) 主页面调用iframe页面的函数: 假如iframe页面有个add函数:
$('#m-iframe')[0].contentWindow.add();
(a) 主页面调用iframe都是通过contentWindow来调用iframe页面的window对象。
(b) 传值就直接传在调用的函数里面。
(2) iframe页面调用主页面函数。
(a) 就如上面的设置高度一样,通过 parent 就能获取到主页面的window对象。
(b) 传值就直接传在调用的函数里面。
(3)回调。 iframe调用父页面函数,父页面响应之后返回回调的值。例子:
//主页面:
var childCallback=null;
$('.box').on('click',function(){
childCallback(1)
})
function show(callback){
if(callback && typeof callback ==='function'){
childCallback=callback;
}
} //iframe页面:
parent.show(function(statu){
console.log(statu);
})
(a)当iframe调用,主页面click事件响应之后,iframe页面就会返回回调的值。
(b) 或者是不用定义变量,直接在调用的函数里面绑定点击事件再回调,不过要注意先取消绑定再绑定,不然会多次触发
3. iframe的弹窗蒙层需要铺满主页面整个页面。例如:

(1) 我推荐的一种方式就是整个弹窗的内容放到主页面里面,iframe只提供触发显示的js就行了。
(2) 网上有些说iframe标签设置absolute和z-index也能达到iframe页面弹窗在主页面之上。我试过,不是不行,iframe页面里的有些内容也会出现在主页面之上。有时候会导致一些问题。
(3) iframe页面对于怎么响应并回调在主页面里面的弹窗,我第二点已经说明了。我认为弹窗放到主页面这样的处理方式比较好。
4.iframe更改了src之后,不出现后退或者前进按钮
要实现这种情况,就只有每次更改的时候,就新建一个iframe元素并替换原来的iframe,这样浏览器就不会产生history,后退和前进按钮就不会激活了
建议前台页面最好少用iframe来引入页面。但是qq邮箱就是用的iframe,为什么我就想不通了。
iframe 自适应高度、父子页面传值、回调的更多相关文章
- jQuery简单实现iframe的高度根据页面内容自适应的方法(转)
本文实例讲述了jQuery简单实现iframe的高度根据页面内容自适应的方法.分享给大家供大家参考,具体如下: 方式1: //注意:下面的代码是放在和iframe同一个页面中调用 $("#i ...
- js控制父子页面传值(iframe和window.open)
在html中,window对象代表浏览器中一个打开的窗口,就像我们C/S中做窗体一样,在该页的window对象就是new了一个新的窗体对象. 就像做C/S开发一样,浏览器是一个软件,每一个网页都是它n ...
- iframe之间通信问题及iframe自适应高度问题
下面本人来谈谈iframe之间通信问题及iframe自适应高度问题. 1. iframe通信 分为:同域通信 和 跨域通信.所谓同域通信是指 http://localhost/demo/iframe/ ...
- 真正的让iframe自适应高度 兼容多种浏览器随着窗口大小改变
今天有朋友问到我关于"iframe自适应高度"的问题,原本以为是很简单的问题,没想到折腾了20分钟才搞定.期间遇到几个问题,要么是高度自适应了,但是当窗口改变时会出现滚动条.也就是 ...
- jquery iframe自适应高度[转]
经典代码 iFrame 自适应高度,在IE6/IE7/IE8/Firefox/Opera/Chrome/Safari通过测试. 很古老的方法: <iframe src="../In ...
- js实现iframe自适应高度
转自:http://www.jb51.net/article/15780.htm 对于自适应高度的代码有很多,可效率什么的考虑进来好代码就不多见了,不过思路倒是差不多的! 不带边框的iframe因为能 ...
- 网页制作技巧:iframe自适应高度
转自:http://www.enet.com.cn/article/2012/0620/A20120620126237.shtml 通过Google搜索iframe 自适应高度,结果5W多条,搜索if ...
- iframe自适应高度的多种方法小结
转自:http://www.jb51.net/article/15780.htm 不带边框的iframe因为能和网页无缝的结合从而不刷新页面的情况下更新页面的部分数据成为可能,可是 iframe的大小 ...
- iframe自适应高度的多种方法方法小结
对于自适应高度的代码有很多,可效率什么的考虑进来好代码就不多见了,不过思路倒是差不多的 不带边框的iframe因为能和网页无缝的结合从而不刷新页面的情况下更新页面的部分数据成为可能,可是 ifram ...
- [转载]再谈iframe自适应高度
Demo页面:主页面 iframe_a.html ,被包含页面 iframe_b.htm 和 iframe_c.html 下面开始讲: 通过Google搜索iframe 自适应高度,结果5W多条,搜索 ...
随机推荐
- ASP.NET没有魔法——ASP.NET MVC IoC代码篇
上一篇文章主要以文字的形式介绍了IoC及其在ASP.NET MVC中的使用,本章将从以下几点介绍如何使用代码在ASP.NET MVC中实现依赖注入: ● AutoFac及安装 ● 容器的创建 ● 创建 ...
- C++调用Opencv实践中遇到的问题备忘录
1.编写一个显示图片的项目,但显示的图片全灰色. 原因:需要在imshow()函数前加一个namedWindow()函数.https://blog.csdn.net/mao_hui_fei/artic ...
- Vue学习之路1-集成环境安装
1.前言 Vue 是一款友好的.多用途且高性能的javascript框架,与其它大型框架不同的是,Vue 被设计为可以自底向上逐层应用,它能够帮你创建可维护性和可测试性更强的代码库,Vue是渐进式的j ...
- 抖音、YouTube、Facebook等新媒体营销与运营相关14本书
最近几年看过的抖音等新媒体营销与运营相关的书有14本,好书不多.具体清单整理如下,点击标题或图片可以看详细点评与内容摘抄: 4星|<屏幕上的聪明决策>:人在手机/电脑上做选择的心理学研究综 ...
- Maven构建项目出现No compiler is provided in this environment. Perhaps you are running on a JRE rather than a JDK?
No compiler is provided in this environment. Perhaps you are running on a JRE rather than a JDK? 你应该 ...
- 交替方向乘子法(ADMM)
交替方向乘子法(ADMM) 参考1 参考2 经典的ADMM算法适用于求解如下2-block的凸优化问题( 是最优值,令 表示一组最优解): Block指我们可以将决策域分块,分成两组变量, 这里面 都 ...
- 爬虫系列---scrapy post请求、框架组件和下载中间件+boss直聘爬取
一 Post 请求 在爬虫文件中重写父类的start_requests(self)方法 父类方法源码(Request): def start_requests(self): for url in se ...
- 一篇文章搞定mongodb
一 安装 1 安装目录下新建文件夹data,etc,logs #在bin文件下启动cmd,指定数据存储的路径mongod --dbpath D:\MongoDB\data\db 2 etc文件夹中新建 ...
- .NET CORE学习笔记系列(6)——KestrelServer
原文:http://www.cnblogs.com/artech/p/KestrelServer.html 跨平台是ASP.NET Core一个显著的特性,而KestrelServer是目前微软推出了 ...
- 【vue】vue全家桶
vue-router(http://router.vuejs.org) vuex(https://vuex.vuejs.org/zh/guide/) vue-resource(https://gith ...