解决iframe显示高度自适应问题

1.解决iframe显示高度自适应问题

2.解决在chrome下ifame跳转高度不能减少

3.解决IE Chrome兼容问题(其它浏览器未测试)

HTML:

<iframe frameborder="0" scrolling="no"  id="iframe" οnlοad="reinitIframeChrome(this)" onreadystatechange="reinitIframeIE(this)">

onreadystatechange这个方法只在IE下适用,Chrome下不会被调用

Javascript:

//iframe高度自适应
function reinitIframeIE(frame) {
if(frame.readyState=="complete"){//待页面加载完成后调整高度
changeHeight();
}
}
function reinitIframeChrome(frame) {
if(document.readyState!="loading"){//待页面加载完成后调整高度
changeHeight();
}
}
function changeHeight(){
var iframeid = document.getElementById("iframe"); // iframe id
iframeid.height = "642px";// 先给一个够小的初值,然后再长高.
iframeid.style.height ="642px";//css也要行被缩小,否则跳转时滚轴长度不会变
if (document.getElementById) {
if (iframeid && !window.opera) {
if (iframeid.contentDocument
&& iframeid.contentDocument.body.offsetHeight) {
iframeid.height = iframeid.contentDocument.body.offsetHeight;
} else if (iframeid.Document && iframeid.Document.body.scrollHeight) {
iframeid.height = iframeid.Document.body.scrollHeight;
}
}
}
iframeid.style.height = iframeid.height+"px";//只有调整css的height后,才被在外围窗口显示滚轴
}

转载于:https://my.oschina.net/u/993228/blog/110481

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值