Note For Me
the place I write down my taste of study
posts - 3,  comments - 13,  trackbacks - 0
原文:http://www.knowsky.com/4928.html

好几次看到有人提问问到如何实现 iframe 的自适应高度,能够随着页面的长度自动的适应以免除页面和 iframe 同时出现滚动条的现象,刚好我在工作中也碰到了类似问题,于是上网翻查,东抄抄西看看,弄出来这么一个函数,贴到页面里面就能用了。不敢独享,大家要是觉得有用,欢迎使用

源代码如下

<script type="text/javascript">
 
//** iframe自动适应页面 **//

 
//输入你希望根据页面高度自动调整高度的iframe的名称的列表
 //用逗号把每个iframe的ID分隔. 例如: ["myframe1", "myframe2"],可以只有一个窗体,则不用逗号。

 
//定义iframe的ID
 var iframeids=["test"]

 
//如果用户的浏览器不支持iframe是否将iframe隐藏 yes 表示隐藏,no表示不隐藏
 var iframehide="yes"

 
function dyniframesize() 
 {
  
var dyniframe=new Array()
  
for (i=0; i<iframeids.length; i++)
  {
   
if (document.getElementById)
   {
    
//自动调整iframe高度
    dyniframe[dyniframe.length] = document.getElementById(iframeids[i]);
    
if (dyniframe[i] && !window.opera)
    {
     dyniframe[i].style.display
="block"
     
if (dyniframe[i].contentDocument && dyniframe[i].contentDocument.body.offsetHeight) //如果用户的浏览器是NetScape
      dyniframe[i].height = dyniframe[i].contentDocument.body.offsetHeight; 
     
else if (dyniframe[i].Document && dyniframe[i].Document.body.scrollHeight) //如果用户的浏览器是IE
      dyniframe[i].height = dyniframe[i].Document.body.scrollHeight;
    }
   }
   
//根据设定的参数来处理不支持iframe的浏览器的显示问题
   if ((document.all || document.getElementById) && iframehide=="no")
   {
    
var tempobj=document.all? document.all[iframeids[i]] : document.getElementById(iframeids[i])
    tempobj.style.display
="block"
   }
  }
 }

 
if (window.addEventListener)
 window.addEventListener(
"load", dyniframesize, false)
 
else if (window.attachEvent)
 window.attachEvent(
"onload", dyniframesize)
 
else
 window.onload
=dyniframesize
</script>


使用的时候只要贴在
<head></head>里面就可以了

posted @ 2005-05-25 16:01 蚌壳 阅读(572) | 评论 (1)编辑 收藏

<2005年5月>
24252627282930
1234567
891011121314
15161718192021
22232425262728
2930311234

常用链接

留言簿(4)

随笔分类(3)

随笔档案(3)

搜索

  •  

最新评论

阅读排行榜

评论排行榜