Iframe 高度自适应
Posted yoo104
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Iframe 高度自适应相关的知识,希望对你有一定的参考价值。
实现 iframe 的自适应高度,能够随着页面的长度自动的适应以免除页面和 iframe 同时出现滚动条的现象。 (需要只有iframe出现滚动条)
刚开始以为是很小的问题一直没注意,但是经常页面比较高的只能显示一半,后来也在网上搜了很多解解办法,一直没真正解决,下面是我在网上搜到的方法:
function iframeAutoFit(iframeObj) { setTimeout(function() { if (!iframeObj) return; iframeObj.height = (iframeObj.Document ? iframeObj.Document.body.scrollHeight : iframeObj.contentDocument.body.offsetHeight); }, 200) }
下面是我的Iframe
<iframe id="MainIframe" onload="iframeAutoFit(this)" name="rightContent" src="@Url.Action("Content","Home")" class="main" frameborder="0" scrolling="no" style="min-height:1000px;"></iframe>
这样可以解决,但是有一个问题,刚加载进来时高度可以正确显示,但是嵌入内容的高度随点击变化(如:下拉菜单,左侧导航栏,上传显示图片等)Iframe高度不会自动适应,为了解决这个问题,我又去搜了一圈,包括在园子里看了一圈也没真正解决,后来仔细想想咱们这样写的是在Iframe加载的是改变的高度,可是我们的内容是在加载以后改变的,应该定一个计时器去随时监测我们的页面高度是否改变了!于是我把上面的方法改了下完美解决问题了。
function iframeAutoFit(iframeObj) { setInterval(function () { if (!iframeObj) return; iframeObj.height = (iframeObj.Document ? iframeObj.Document.body.scrollHeight : iframeObj.contentDocument.body.offsetHeight); }, 200) }
虽然是个小问题,但是发现网上搜的方法都没解决我的问题,于是写出来分享给大家,不知道解决你的问题没有呢?
以上是关于Iframe 高度自适应的主要内容,如果未能解决你的问题,请参考以下文章