td自适应iframe iframe自适应高度的多种方法方法小结
转自:http://hi.baidu.com/kukuyan/blog/item/11e12e97a78fca6554fb9623.html
td自适应iframe 高度收藏
<td id="mainFrameTd" width="414" align="center" valign="top">
<script>
function resize(obj){
var iframeHeight=document.frames[obj.name].document.body.scrollHeight;
alert(iframeHeight);
document.getElementById("mainFrameTd").style.height=iframeHeight;
}
</script>
<iframe frameborder="0" name="index_main" id="index_main" onload="resize(this);" src="${getUrl()}" style="width:100%; height:100%" scrolling="no"></iframe>
</td>
本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/xkyle/archive/2008/09/11/2914640.aspx
iframe自适应高度的多种方法方法小结
<script language="javascript">
//输入你希望根据页面高度自动调整高度的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>
网 上有人改进了方法,解决了当iframe所包含文档内容高度动态变化时自动调整iframe高度的问题,原理是在iframe所在页面不断扫描 iframe包含文档的内容高度并改变iframe自身高度,这种方法貌似解决了问题,但是对页面速度和系统资源占用是否有影响还很难说,感觉方法有些偏 执,应该有更好的解决方法。
第二种方法,只针对知道的iframe的ID调用
function iframeAutoFit(iframeObj){
setTimeout(function(){if(!iframeObj) return;iframeObj.height=(iframeObj.Document?iframeObj.Document.body.scrollHeight:iframeObj.contentDocument.body.offsetHeight);},200)
}
浙公网安备 33010602011771号