iframe自适应高度并解决jquery ajax获取数据后高度自适应问题
很多管理系统中,都使用iframe进行信息内容的展示方式,或者作为主菜单的链接展示内容。
使用iframe的问题就是自适应高度的问题。
iframe自适应高度本身是很简单的方法,就是在页面加载完成后,重新计算一下高度即可。代码如下:
//公共方法:设置iframe的高度以保证全部显示数据 var iframeLoaded = function (iframe) { if (iframe.src.length > 0) { if (!iframe.readyState || iframe.readyState == "complete") { var bHeight = iframe.contentWindow.document.body.scrollHeight; var dHeight = iframe.contentWindow.document.documentElement.scrollHeight; var height = Math.max(bHeight, dHeight); iframe.height = height; } } } //分页时重新设置 iframe 高度 ; 修改后:iframe.name = iframe.id var reSetIframeHeight = function(){ try { var oIframe = parent.document.getElementById(window.name); oIframe.height = 100; iframeLoaded(oIframe); } catch (err){ try { parent.document.getElementById(window.name).height = 1000; } catch (err2) { } } }
调用reSetIframeHeight();方法即可。
但是还有一种情况就是使用jquery ajax请求数据,数据都是在body load完成后,还在进行http请求,这时候没有数据占据窗口高度,reSetIframeHeight方法无法计算出来高度。
这时候,我们想到一个方法:ajax什么时候能够执行完成,当然是Complete事件是执行完成。
但是我们也不能在每一个页面里的ajax Complete事件中添加处理。这里就用到了jquery ajax的全局变量。
这里有介绍:[Jquery $.ajax请求详解及ajax全局变量分析]
处理ajax和iframe自适应的代码:
var sendcount = 0; var completecount = 0; // 添加ajax全局事件处理。 reSetIframeHeight(); $(document).ajaxStart(function (a, b, c) { }).ajaxSend(function (e, xhr, opts) { sendcount++; }).ajaxError(function (e, xhr, opts) { }).ajaxSuccess(function (e, xhr, opts) { }).ajaxComplete(function (e, xhr, opts) { completecount++; reSetIframeHeight(); }).ajaxStop(function () { });
先执行一下reSetIframeHeight,再在每个ajax完成后调用reSetIframeHeight。
原文出处:http://www.suchso.com/projecteactual/jquery-ajax-iframe-resetiframeheight.html
相关文章:http://xiaosa.blog.51cto.com/665033/1227753
相关推荐
我只是个程序员 2014-01-18
架构技术交流 2020-07-28
haohong 2020-07-18
tiankele0 2020-06-26
xiangxiaojun 2020-06-25
pythonclass 2020-06-04
WebVincent 2020-06-03
sixthelement 2020-05-30
云之高水之远 2020-05-19
云之高水之远 2020-05-17
Chydar 2020-05-15
tuxlcsdn 2020-04-17
ajaxtony 2020-02-03
STPace 2020-02-03
学留痕 2013-05-11
云之高水之远 2020-01-05
TONIYH 2019-12-20
nimeijian 2019-12-15