解决IFrame高度自适应
2009-11-03 13:03
441 查看
解决IFrame高度自适应
在做项目中,在主页面Table中使用的Iframe框架,但是在设置Iframe的高度和宽度后,框架就失去了作用,不显示框架中加载的页面
经过检查,总算找到了问题所在,当把Iframe的高度设置一个固定值后,页面就可以显示,但是我们不能准确知道页面的高度,页面的
高度会随着屏幕的高度而改变。
通过查找资料,找到了解决办法
Code
<table>
<tr>
<td>
</td>
</tr>
<tr>
<td style="vertical-align:top;width: 100%; height:100%;" >
<iframe id="bottom" name="bottom" frameborder="1" width=100% scrolling="auto" src="Main.aspx"></iframe>
</td>
</tr>
</table>
JavaScript代码:
Code
<script language="JavaScript">
//** iframe自动适应页面 **//
//输入你希望根据页面高度自动调整高度的iframe的名称的列表
//用逗号把每个iframe的ID分隔. 例如: ["myframe1", "myframe2"],可以只有一个窗体,则不用逗号。
//定义iframe的ID
var iframeids=["bottom"]
//如果用户的浏览器不支持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>
如需转载请加入本人Blog地址
http://zhf.cnblogs.com/
Tag标签: 框架,iframe,height,高度
在做项目中,在主页面Table中使用的Iframe框架,但是在设置Iframe的高度和宽度后,框架就失去了作用,不显示框架中加载的页面
经过检查,总算找到了问题所在,当把Iframe的高度设置一个固定值后,页面就可以显示,但是我们不能准确知道页面的高度,页面的
高度会随着屏幕的高度而改变。
通过查找资料,找到了解决办法
Code
<table>
<tr>
<td>
</td>
</tr>
<tr>
<td style="vertical-align:top;width: 100%; height:100%;" >
<iframe id="bottom" name="bottom" frameborder="1" width=100% scrolling="auto" src="Main.aspx"></iframe>
</td>
</tr>
</table>
JavaScript代码:
Code
<script language="JavaScript">
//** iframe自动适应页面 **//
//输入你希望根据页面高度自动调整高度的iframe的名称的列表
//用逗号把每个iframe的ID分隔. 例如: ["myframe1", "myframe2"],可以只有一个窗体,则不用逗号。
//定义iframe的ID
var iframeids=["bottom"]
//如果用户的浏览器不支持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>
如需转载请加入本人Blog地址
http://zhf.cnblogs.com/
Tag标签: 框架,iframe,height,高度
相关文章推荐
- 解决iframe跨域高度自适应问题
- iframe框架高度自适应在兼容模式下(ie7)不兼容的解决方法
- Iframe实现跨浏览器自适应高度解决方法
- Iframe实现跨浏览器自适应高度解决方法
- 解决父窗体内Iframe高度自适应问题
- 两段超简单jquery代码解决iframe自适应高度问题(不用判断浏览器高度)
- 真正解决iframe自适应高度
- iframe自适应高度,多层嵌套iframe自适应高度的解决方法
- 解决火狐iframe自适应高度,兼容IE6、7、8
- 【原】 iFrame 自适应高度解决不了的问题所在和解决办法
- ExtJs非Iframe框架加载页面实现 解决自适应高度
- iframe高度自适应问题解决方案
- 解决IE,Firefox,chrome,safari浏览器中iframe显示高度自适应问题
- 两段超简单jquery代码解决iframe自适应高度问题(不用判断浏览器高度)
- JS解决iframe之间通信和自适应高度的问题
- JS跨域解决iframe高度自适应(IE8/Firefox/Chrome适用)
- 对iFrame 自适应高度的解决办法
- 解决iFrame自适应高度(兼容IE6,IE7与FireFox)
- jQuery解决iframe高度自适应代码
- iFrame 跨域高度自适应问题解决