第一种方法:代码简单,兼容性还可以,大家可以先测试下。
function SetWinHeight(obj)
{
var win=obj;
if (document.getElementById)
{
if (win && !window.opera)
{
if (win.contentDocument && win.contentDocument.body.offsetHeight)
win.height = win.contentDocument.body.offsetHeight;
else if(win.Document && win.Document.body.scrollHeight)
win.height = win.Document.body.scrollHeight;
}
}
}
最后,加入iframe,不能丢掉onload属性,当然了,id也必须也函数中的win匹配
<iframe width=778 align=center height=200 id=win name=win onl oad=Javascript:SetWinHeight(this) frameborder=0 scrolling=no src=1.htm></iframe>
这么的这种也是跟上面的解决方法类似的代码
经典代码 iFrame 自适应高度,在IE6/IE7/IE8/Firefox/Opera/Chrome/Safari通过测试。
HTML代码:
<iframe src=http://www.downcc.com/ id=iframepage name=iframepage frameBorder=0 scrolling=no width=100% onl oad=iFrameHeight() ></iframe>Javascript代码:
<script type=text/javascript language=javascript>
function iFrameHeight() {
var ifm= document.getElementById(iframepage);
var subWeb = document.frames ? document.frames[iframepage].document : ifm.contentDocument;
if(ifm != null && subWeb != null) {
ifm.height = subWeb.body.scrollHeight;
}
}
</script>
下面这个兼容性更好一些
<script language=javascript type=text/javascript>
function dyniframesize(down) {
var pTar = null;
if (document.getElementById){
pTar = document.getElementById(down);
}
else{
eval(pTar = + down + ;);
}
if (pTar && !window.opera){
/begin resizing iframe
pTar.style.display=block
if (pTar.contentDocument && pTar.contentDocument.body.offsetHeight){
/ns6 syntax
pTar.height = pTar.contentDocument.body.offsetHeight +20;
pTar.width = pTar.contentDocument.body.scrollWidth+20;
}
else if (pTar.Document && pTar.Document.body.scrollHeight){
/ie5+ syntax
pTar.height = pTar.Document.body.scrollHeight;
pTar.width = pTar.Document.body.scrollWidth;
}
}
}
</script>
<iframe src =/default2.aspx frameborder=0 marginheight=0 marginwidth=0 frameborder=0 scrolling=auto id=ifm name=ifm onl oad=javascript:dyniframesize(ifm); width=100%>
</iframe>
另一种情况的iframe解决方案(超简单)
重要提示:src=中你必须填写的网页地址,一定要和本页面在同一个站点上,否则,会抱错,说“拒绝访问!”(实际上这是因为Js的跨域问题导致拒绝访问的)
之前自己也碰到过这个问题,为了得到答案去网上搜索,发现有不少人也遇到了这样的问题,现在就把解决方法共享一下
1、建立一个bottom.js的文件,然后输入下面的代码(只有两行哦)
parent.document.all(框架ID名).style.height=document.body.scrollHeight;
parent.document.all(框架ID名).style.width=document.body.scrollWidth;
这里的 框架ID名 就是Iframe的ID,比如:
<iframe id=框架ID名 name=left frameBorder=0 scrolling=no src=XXX.asp width=100%></iframe>
2、给你网站里所有的被包含文件里面每个都加入
<script language = JavaScript src = bottom.js/></script>
3、OK,收工!
在WINXP、IE6下面测试通过。很简单吧!
实现 iframe 的自适应高度
实现 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);
if (dyniframe && !window.opera)
{
dyniframe.style.display=block
if (dyniframe.contentDocument && dyniframe.contentDocument.body.offsetHeight) /如果用户的浏览器是NetScape
dyniframe.height = dyniframe.contentDocument.body.offsetHeight;
else if (dyniframe.Document && dyniframe.Document.body.scrollHeight) /如果用户的浏览器是IE
dyniframe.height = dyniframe.Document.body.scrollHeight;
}
}
/根据设定的参数来处理不支持iframe的浏览器的显示问题
if ((document.all || document.getElementById) && iframehide==no)
{
var tempobj=document.all? document.all[iframeids] : document.getElementById(iframeids)
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属性src所指定的包含文档中内容的高度,然后用来设置iframe自身的高度,在iframe所在页面载入时对页面中的所有需要自适应高度的iframe进行自动设置,省时省力,如果确定页面中全部iframe都需要自适应高度,直接取得iframe数组给代码,就连ID都不用自己写了,完成程序搞定。(代码贴上来:)
<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
关键词:iframe

