!
也想出现在这里? 联系我们
广告位

CSS完美实现iframe高度自适应(支持跨域)

Iframe 的强大功能偶就不多说了,它不但被开发人员经常运用,而且黑客们也常常使用它,总之用过的人知道它的强大之处,但是 Iframe 有个致命的“BUG”就是 iframe 的高度无法自动适应,这一点让很多人都头疼万分。百度或是谷歌一下,确实很多解决方法,但尝试一下,会发现问题很多:浏览器兼容性差,不能自适应,仅支持同域 Iframe 等诸多问题,尤其是跨域 Iframe 高度自适应问题。网上根本找不到一种可行的方案(唯一有一种提到加入代理页面的,经过测试发现无用)。难道真的没有一种可行的解决方案了吗? No,下面和大家分享一种强大的方法,代码如下:

方法一

  1. <html>
  2. <head>
  3. <style>
  4. body {margin-left: 0px;margin-top: 0px;margin-right: 0px;margin-bottom: 0px;overflow: hidden;}
  5. </style>
  6. </head>
  7. <body>
  8. <iframe src="http://www.22vd.com/" width='100%' height='100%' frameborder='0' name="_blank" id="_blank" ></iframe>
  9. </body>
  10. </html>

代码强大之处:

1. 该方法完美兼容 IE6,7,8 ,Fire fox,chrome,opera 等主流的浏览器;

2.同域,跨域皆支持;

3.不调用任何 JS 脚本;

注意三点

1. 文件开头不能是:

必须 是开头

2. body 样式中的 overflow: hidden; 绝对不对省略;

3.Iframe 中的 height='100%' 以及 滚动条不能设为 no(默认是 yes,不用设置即可)

方法二

iframe 嵌套界面自适应是一个比较常见的功能需求,但是目前网上搜索出来的均不能做到自适应功能,下面是我列出来的第二种解决方案,分享给大家,使用原生的 JS 编写,适用于 chrome,firefox,IE 浏览器,下面是代码部分。

  1. <div class="main_page">
  2. <iframe scrolling="no" id="main" name="main" frameborder="0" src="" style="min-height:600px;width:100%;height:100%;"></iframe>
  3. </div>
  1. <script>
  2. // 计算页面的实际高度,iframe自适应会用到
  3. function calcPageHeight(doc) {
  4. var cHeight = Math.max(doc.body.clientHeight, doc.documentElement.clientHeight)
  5. var sHeight = Math.max(doc.body.scrollHeight, doc.documentElement.scrollHeight)
  6. var height = Math.max(cHeight, sHeight)
  7. return height
  8. }
  9. //根据ID获取iframe对象
  10. var ifr = document.getElementById('main')
  11. ifr.onload = function() {
  12. //解决打开高度太高的页面后再打开高度较小页面滚动条不收缩
  13. ifr.style.height='0px';
  14. var iDoc = ifr.contentDocument || ifr.document
  15. var height = calcPageHeight(iDoc)
  16. if(height < 850){
  17. height = 850;
  18. }
  19. ifr.style.height = height + 'px'
  20. }
  21. </script>

亲测谷歌、火狐、ie8+通过,马上试试吧。100%不会让你失望。

给TA打赏
共{{data.count}}人
人已打赏
前端学习

文章标题链接平滑右移效果代码

2024-8-23 15:02:07

前端学习

利用animation动画实现呼吸灯效果

2024-8-23 15:02:10

下载说明

  • 1、微码盒所提供的压缩包若无特别说明,解压密码均为weimahe.com
  • 2、下载后文件若为压缩包格式,请安装7Z软件或者其它压缩软件进行解压;
  • 3、文件比较大的时候,建议使用下载工具进行下载,浏览器下载有时候会自动中断,导致下载错误;
  • 4、资源可能会由于内容问题被和谐,导致下载链接不可用,遇到此问题,请到文章页面进行反馈,以便微码盒及时进行更新;
  • 5、其他下载问题请自行搜索教程,这里不一一讲解。

站长声明

本站大部分下载资源收集于网络,只做学习和交流使用,版权归原作者所有;若为付费资源,请在下载后24小时之内自觉删除;若作商业用途,请到原网站购买;由于未及时购买和付费发生的侵权行为,与本站无关。本站发布的内容若侵犯到您的权益,请联系本站删除,我们将及时处理!
0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索