订阅邮件
快捷导航

iframe自适应高度的多种方法方法小结

[复制链接]
查看: 3277|回复: 8
发表于 2012-9-12 15:48:49 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转合天下互动社区。

您需要 登录 才可以下载或查看,没有帐号?中文注册

x
对于自适应高度的代码有很多,可效率什么的考虑进来好代码就不多见了,不过思路倒是差不多的8 \# q8 g8 ^: K3 W9 P2 Z  j2 Z
不带边框的iframe因为能和网页无缝的结合从而不刷新页面的情况下更新页面的部分数据成为可能,可是 iframe的大小却不像层那样可以“伸缩自如”,所以带来了使用上的麻烦,给iframe设置高度的时候多了也不好,少了更是不行,现在,让我来告诉大 家一种iframe动态调整高度的方法,主要是以下JS函数:
# z3 a) I+ T: O8 @$ l; |第一种方法:代码简单,兼容性还可以,大家可以先测试下。* l1 ~  E" K9 Z3 n) r$ Q5 f
复制代码 代码如下:" }: o  b+ J( u/ y1 @- Y. M
function SetWinHeight(obj)
0 z3 z# K+ L5 z# t{
4 W! \4 l# a0 x( D" rvar win=obj;
! V/ ^( F6 \0 u  fif (document.getElementById) ; I5 F  J* P. _! X% c
{
! {. Q+ ]* v# ^2 @if (win && !window.opera) 2 K! P. W1 F' R) }% M
{
; |/ p% M* }4 C7 `4 Zif (win.contentDocument && win.contentDocument.body.offsetHeight) & M2 D- v3 a. Q/ M7 D, ]+ r& O
win.height = win.contentDocument.body.offsetHeight; ) z: v7 V! N1 p
else if(win.Document && win.Document.body.scrollHeight)
5 V/ ~% P5 G! v9 ^win.height = win.Document.body.scrollHeight; % ]" [( @! j! `0 c7 y# y
} 7 M( P2 l5 V9 a1 X5 J! T
}
. q# r& I7 a4 ~0 v/ C  x}
( y3 X* w9 k. J& V) R' y9 j- w+ P3 b, p. s+ v% [
最后,加入iframe,不能丢掉onload属性,当然了,id也必须也函数中的win匹配 / x4 i% V) H8 m( P6 l. z
复制代码 代码如下:
& ]( n& }  Q8 K. Y3 @6 w6 B/ J/ Y6 z<iframe width="778" align="center" height="200" id="win" name="win" frameborder="0" scrolling="no" src="1.htm"></iframe>
1 @9 u! E% Z. r: i# P2 U( F+ ]- ~( S3 }9 n) Y
这么的这种也是跟上面的解决方法类似的代码
! H- W- l( h6 W7 B经典代码 iFrame 自适应高度,在IE6/IE7/IE8/Firefox/Opera/Chrome/Safari通过测试。 2 J$ V+ p$ [& m7 i+ a  t, E6 z
HTML代码:
; K, m9 D4 a2 s" x: i% G3 f: s  \复制代码 代码如下:( \! O/ ~$ U' Y' G0 m  U
<iframe src="http://www.fufuok.com/" id="iframepage" name="iframepage" frameBorder=0 scrolling=no width="100%" ></iframe>Javascript代码:
7 A; q! R" c' |1 H! a4 P8 |1 _<script type="text/javascript" language="javascript"> 7 y3 Q! N' m0 O" T1 E5 E1 B
function iFrameHeight() {
& s! }2 R9 h6 g2 @/ e# G& D+ svar ifm= document.getElementById("iframepage"); 2 G! }; P+ q$ b- U; t% f0 d
var subWeb = document.frames ? document.frames["iframepage"].document : ifm.contentDocument; + A- W+ p, f& d- \" @
if(ifm != null && subWeb != null) { & W2 w& J/ b: b& G3 e
ifm.height = subWeb.body.scrollHeight;
* `" q1 q+ g) @" q6 }% g% S0 s; ?} , u2 C4 _* L& f. X4 Y9 V
} ; t/ G/ D/ B+ `: r0 m  Y) _
</script>
" ]3 L, }8 J* c; r( i% G: v0 n: f. E; t6 r" v+ p, W
# k1 }  S! C* J9 Y) U
下面这个兼容性更好一些* f- k0 R" h9 H( X* c) m+ H5 Y" y- A
复制代码 代码如下:. t$ L6 S+ F' b
<script language="javascript" type="text/javascript">
# ^- `0 n  r  d% m& b' E8 `4 s" B8 ffunction dyniframesize(down) { ! `# L* G- N4 z+ w
var pTar = null;
) i; a/ l0 u# f: Y0 a8 Z, I& a# rif (document.getElementById){ 1 u: U3 l4 i; r9 \6 Z/ i- M7 F  C
pTar = document.getElementById(down); 0 Z2 U2 d- k8 s4 r7 B
} . {( r& U9 Y3 J  \
else{ 0 |( Y- ?; z: ]% ?) F, C
eval('pTar = ' + down + ';'); 9 N) C2 e. {- ^" a8 g
}
0 I  X% V# |, \( T* V; v$ e9 {if (pTar && !window.opera){ ; `4 M: i! h$ n) o
//begin resizing iframe
4 w% K& D% k/ q$ O: d* Z# |. P9 F8 fpTar.style.display="block" 5 o/ p% Q: L  r5 E; U% D8 s% g
if (pTar.contentDocument && pTar.contentDocument.body.offsetHeight){
  ]% ]" ?$ u, ^9 M( }//ns6 syntax
4 B* h& H1 O; LpTar.height = pTar.contentDocument.body.offsetHeight +20;
9 w, M3 Z) t. P2 o) p* K; RpTar.width = pTar.contentDocument.body.scrollWidth+20;
' q5 u4 M3 A( h  m+ X* R2 @} $ k+ M2 n5 D1 ^( Z
else if (pTar.Document && pTar.Document.body.scrollHeight){
  a+ I* i7 o4 e% R. Q; k//ie5+ syntax " z/ o/ Q- e+ T" B
pTar.height = pTar.Document.body.scrollHeight; 1 W! G, D2 j: \# p; O+ p4 q
pTar.width = pTar.Document.body.scrollWidth; ) n7 J5 N3 y- C5 N* t2 w
}
' V1 G2 y4 X. W8 M  Y" [. K} # r8 |; W3 [$ _+ y
}
/ A+ f1 g5 x2 h4 K</script>
3 p! y" ?6 o8 B; h* t<iframe src ="/default2.aspx" frameborder="0" marginheight="0" marginwidth="0" frameborder="0" scrolling="auto" id="ifm" name="ifm" width="100%"> ! |* D; R( k7 }& z
</iframe>
0 u2 ^. j- G9 w$ W4 R& M. j
$ U( @& j- K0 T  \$ p* b7 U* ^
4 n  J( S  f7 d: f- @9 ?另一种情况的iframe解决方案(超简单)
5 k9 y/ @9 v. j重要提示:src=中你必须填写的网页地址,一定要和本页面在同一个站点上,否则,会抱错,说“拒绝访问!”(实际上这是因为Js的跨域问题导致拒绝访问的) . n% h8 k' u6 A5 w9 W' _8 V
之前自己也碰到过这个问题,为了得到答案去网上搜索,发现有不少人也遇到了这样的问题,现在就把解决方法共享一下
4 ~" A5 g5 N+ a, L7 F" c9 t1、建立一个bottom.js的文件,然后输入下面的代码(只有两行哦) : k5 O3 P" d9 W* }
复制代码 代码如下:( ?' x& v0 |; u8 X5 O! A1 u" r
parent.document.all("框架ID名").style.height=document.body.scrollHeight; 7 b' z; V- W1 u
parent.document.all("框架ID名").style.width=document.body.scrollWidth; : b3 h1 ~# r% e) }
7 r% F; p  a9 ?
这里的 框架ID名 就是Iframe的ID,比如: ( G  I0 O0 g+ Z" a3 t0 H
复制代码 代码如下:: L3 X. K4 ~4 `8 m5 x- v6 P
<IFRAME id="框架ID名" name="left" frameBorder=0 scrolling=no src="XXX.asp" width="100%"></IFRAME>
: w: J1 @/ N2 [  a% h6 T, i& w! @7 A) ]$ |  k+ n9 `
2、给你网站里所有的被包含文件里面每个都加入 + a7 p+ A+ Y9 w8 a+ P
复制代码 代码如下:# q3 v$ O8 p' S3 @$ Q! Z/ w
<script language = "JavaScript" src = "bottom.js"/></script> + g/ n7 K, C$ @8 P1 v( f7 a6 w6 @

9 b7 A; B) ?- G% H4 e+ }  ]3、OK,收工!
: f5 Z; D; q8 q, \6 j- @在WINXP、IE6下面测试通过。很简单吧! + K: W7 b$ b6 T7 d/ C, Z
实现 iframe 的自适应高度 : b' P  h% q5 ^! X
实现 iframe 的自适应高度,能够随着页面的长度自动的适应以免除页面和 iframe 同时出现滚动条的现象。
. b2 v4 S" K7 ?! E2 a复制代码 代码如下:1 F; u7 p+ c' r) ], q- n; l3 _! B
<script type="text/javascript"> 5 Z0 X' R2 C# s$ Z* a) Y$ `- W2 \& k' w
//** iframe自动适应页面 **// - R; O) l9 K2 g3 e
//输入你希望根据页面高度自动调整高度的iframe的名称的列表 6 I: g/ I% u* a, A
//用逗号把每个iframe的ID分隔. 例如: ["myframe1", "myframe2"],可以只有一个窗体,则不用逗号。   M) y$ D( F; s1 s4 p
//定义iframe的ID
4 n, \7 w. t9 dvar iframeids=["test"]
4 x9 E3 \* \0 E2 k% V. n//如果用户的浏览器不支持iframe是否将iframe隐藏 yes 表示隐藏,no表示不隐藏
) a" K2 [$ s' H, ~var iframehide="yes"
" u- M; J: R" ]# h: Ffunction dyniframesize() * {' i( K2 O% W* o5 _
{
; ~. W8 O# {, C1 ^var dyniframe=new Array() , V: _' e- M+ G+ V8 y
for (i=0; i<iframeids.length; i++)
$ |" j! H; r0 U2 [( t$ h, a2 r# K{ * g" T9 I, p+ ~( }) w/ }
if (document.getElementById)
/ M$ m4 }6 d1 ~+ U{
' m) F; I; a+ A, A7 ^//自动调整iframe高度 4 _6 T: e* k( b0 @2 Q$ o, H
dyniframe[dyniframe.length] = document.getElementById(iframeids); 9 [. O+ D% V' [7 j5 A+ o% E
if (dyniframe && !window.opera) 8 R! G" W! s2 L+ r/ v
{
, e0 l5 N& |' w; J% R9 @1 Jdyniframe.style.display="block"
' }/ R5 y( P# M7 ^& d+ mif (dyniframe.contentDocument && dyniframe.contentDocument.body.offsetHeight) //如果用户的浏览器是NetScape 7 X; _5 Z  w0 S$ }( t+ e4 c1 p
dyniframe.height = dyniframe.contentDocument.body.offsetHeight; 2 _3 v% m5 k9 U0 y+ W% G* [' z! u
else if (dyniframe.Document && dyniframe.Document.body.scrollHeight) //如果用户的浏览器是IE , s( c# j" }8 u/ ^  u
dyniframe.height = dyniframe.Document.body.scrollHeight;
: U8 F5 d  _9 b, V: O2 |) j6 n; H; Z* i} 4 _+ s! A1 m  g- l1 x) z, H" r
}
* T& l. _9 H3 e( I9 g* [//根据设定的参数来处理不支持iframe的浏览器的显示问题 ! a# Z/ d, I" W
if ((document.all || document.getElementById) && iframehide=="no")
7 l2 X, {9 R, a% L- x$ f9 T{ " ?: s7 W  z) }3 U( Q
var tempobj=document.all? document.all[iframeids] : document.getElementById(iframeids) # _2 K- O! P- g/ B  A  Z$ E
tempobj.style.display="block"
6 B* i" C! d8 U& |}
8 f  z3 n5 g' F: d}
! Q0 n4 H* j# p+ F}
. \3 _5 s+ e: m9 c; z3 Cif (window.addEventListener)
6 M5 E* _: J( X$ V& y/ Y' Kwindow.addEventListener("load", dyniframesize, false)
4 D6 g! ~# r2 h# L$ Telse if (window.attachEvent) 9 f7 s+ {" H, `7 \4 o
window.attachEvent("onload", dyniframesize)
, }( H- _: q( B9 ~6 @; Nelse
# `; f1 c4 o2 V) K" t* nwindow.onload=dyniframesize + X6 \4 T4 {( {( P$ j
</script> ) ^6 s3 G# n7 `3 @
! X" X# y$ Q+ r3 Z- P
第三中方法批量iframe自适应:
8 t% Z8 X1 ]! E  f工作中遇到iframe随所含内容自适应高度的问题,以前在网上看到过类似问题的解决方法,于是搜索一下,找到了一个比较完整的能够兼容浏览器的解决方法,省得自己写了。- q1 Q% o! z: @" a
虽然不用自己写,思路还是要明白,基本上就是取得iframe属性src所指定的包含文档中内容的高度,然后用来设置iframe自身的高度,在iframe所在页面载入时对页面中的所有需要自适应高度的iframe进行自动设置,省时省力,如果确定页面中全部iframe都需要自适应高度,直接取得iframe数组给代码,就连ID都不用自己写了,完成程序搞定。(代码贴上来:) ' K( M' m, Z- p- {+ Z* @( C3 P
复制代码 代码如下:
- N2 T% \9 i0 g7 W( [<script language="javascript"> " e" b0 d- d. g( W7 B5 Q
//输入你希望根据页面高度自动调整高度的iframe的名称的列表 ' E) U* ~! k" J3 J5 v
//用逗号把每个iframe的ID分隔. 例如: ["myframe1", "myframe2"],可以只有一个窗体,则不用逗号。 " y  g1 u- ?5 N, B1 y. L. V; \
//定义iframe的ID " A9 w6 l7 C: E' p
var iframeids=["test"]; ! n, Z! H6 w. }! g9 K* G
//如果用户的浏览器不支持iframe是否将iframe隐藏 yes 表示隐藏,no表示不隐藏 $ ~$ k6 A3 P9 p: m" i0 _! a
var iframehide="yes"; * N/ _& T4 ?) m
function dyniframesize()
+ u! ?  _4 Y( @{
0 Q6 F% o; e# Y: f/ ~2 y* @. \+ qvar dyniframe=new Array()
( `! I  D  U. O# W* r9 Ufor (i=0; i<iframeids.length; i++) : n  k2 Y, ~( \" Z3 i0 H
{
5 F/ Q( L. x$ ^0 {# s* gif (document.getElementById)
1 }2 l$ V9 {5 Q9 I: D- n/ u{ 8 h" Q- z0 H/ k8 I- S/ E& O2 Y
//自动调整iframe高度
1 ?3 ]7 D6 v4 @% Q7 r1 edyniframe[dyniframe.length] = document.getElementById(iframeids); 7 {8 E% C* o' b/ n$ E& v
if (dyniframe && !window.opera) 5 _& E! n) m% X7 Y
{
  R$ u, G$ A& G, Edyniframe.style.display="block"; ; ~8 Z$ Q" ]: i( e9 x7 @: H) e
if (dyniframe.contentDocument && dyniframe.contentDocument.body.offsetHeight) //如果用户的浏览器是NetScape . f1 K7 C0 |2 K) _  _: ^0 I- j  w+ p+ A
dyniframe.height = dyniframe.contentDocument.body.offsetHeight;
1 ]% A7 F+ u/ J8 s) delse if (dyniframe.Document && dyniframe.Document.body.scrollHeight) //如果用户的浏览器是IE
' q/ \+ q+ f" c" \& Mdyniframe.height = dyniframe.Document.body.scrollHeight;
# r4 v; y" b5 a0 @1 G/ R% l}
- i6 h# C* r& _' i3 H}
4 N2 q* [0 U) s, ^//根据设定的参数来处理不支持iframe的浏览器的显示问题 1 P$ U$ e/ \! W7 E* S, n5 }
if ((document.all || document.getElementById) && iframehide=="no") 5 d4 O& _) M( R; {
{
( X* P) u9 f8 d$ m; Fvar tempobj=document.all? document.all[iframeids] : document.getElementById(iframeids); 8 h( A- a  t9 G/ r* U
tempobj.style.display="block"; 2 U: l. k' @. b/ p% i* D% _
}
3 q/ ~& N9 @$ W} 3 L5 T9 Q. Z. R  l
}
  F) W3 K; z3 @& k& Z0 _) @if (window.addEventListener) ; T7 D( B* n/ M* @1 }; q( X
window.addEventListener("load", dyniframesize, false);
! ^5 u' o: n# n5 Y- |  W2 k6 Melse if (window.attachEvent)
5 \5 {& P) O5 d7 Iwindow.attachEvent("onload", dyniframesize); + U2 w% ]. Q+ a5 q# m
else
2 F" p6 Y/ h: o* ^- jwindow.onload=dyniframesize;
: I0 P' T8 Z, A' `, B) U- {</script> & E" ?+ ]$ |9 m) G. [

% B4 P1 G% s% _- r2 {5 Q6 ]
5 d+ E. A5 W# o2 I# J1 N网上有人改进了方法,解决了当iframe所包含文档内容高度动态变化时自动调整iframe高度的问题,原理是在iframe所在页面不断扫描iframe包含文档的内容高度并改变iframe自身高度,这种方法貌似解决了问题,但是对页面速度和系统资源占用是否有影响还很难说,感觉方法有些偏执,应该有更好的解决方法。
7 S, R" q" n- @& s* o4 i5 A7 K/ U' M第四种方法,只针对知道的iframe的ID调用 不推荐6 a4 B* `  d# i% Q2 v
复制代码 代码如下:
% E/ c; ?5 T' M! {& h1 Y9 qfunction iframeAutoFit(iframeObj){
# x5 q- F  A' Q- G: J0 _setTimeout(function(){if(!iframeObj) return;iframeObj.height=(iframeObj.Document?iframeObj.Document.body.scrollHeight:iframeObj.contentDocument.body.offsetHeight);},200)
% [% v5 L" ^; x+ \}
1 O1 u0 ~; V% D3 U/ I: q, V8 c1 y2 _% s
使用方法呢,大家在需要自适应的iframe上加个id,然后js执行就可以了
$ c0 r9 F: B8 }- b( L详细出处参考:http://www.jb51.net/article/15780.htm$ P5 i# Z) @; o- A

0 b. t0 U( K1 N1 R* y
维卡官网:www.onelife.eu
发表于 2012-9-29 18:10:03 | 显示全部楼层
呵呵 高高实在是高~~~~~  
维卡官网:www.onelife.eu
发表于 2012-9-29 18:10:03 | 显示全部楼层
呵呵 大家好奇嘛 来观看下~~~~  
维卡官网:www.onelife.eu
发表于 2012-11-1 15:49:40 | 显示全部楼层
回答了那么多,没有加分了,郁闷。。  
维卡官网:www.onelife.eu
发表于 2012-11-1 15:49:40 | 显示全部楼层
一个有信念者所开发出的力量,大于99个只有兴趣者。  
维卡官网:www.onelife.eu
发表于 2012-11-12 09:33:55 | 显示全部楼层
真的有么  
维卡官网:www.onelife.eu
发表于 2012-11-12 09:33:55 | 显示全部楼层
朕要休息了.............. 888888
维卡官网:www.onelife.eu
发表于 2012-11-12 09:33:55 | 显示全部楼层
要相信自己~智商为0  
维卡官网:www.onelife.eu
发表于 2012-11-12 09:33:55 | 显示全部楼层
人生感悟:牵手时,即使你的手有多汗,也别放开。  
维卡官网:www.onelife.eu
您需要登录后才可以回帖 登录 | 中文注册

本版积分规则

精彩推荐
Copyright   ©2018-2020  One生态中文学习网  Powered by©onelife     豫ICP备12023128号 豫公网安备41010302002471号