码迷,mamicode.com
首页 > 其他好文 > 详细

Iframe 高度自适应

时间:2019-01-21 17:53:31      阅读:134      评论:0      收藏:0      [点我收藏+]

标签:内容   fun   scroll   offset   color   监测   tin   his   一个   

 实现 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 高度自适应

标签:内容   fun   scroll   offset   color   监测   tin   his   一个   

原文地址:https://www.cnblogs.com/yoo104/p/10299907.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!