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

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

概述iframe嵌套界面自适应是一个比较常见的功能需求,但是目前网上搜索出来的均不能做到自适应功能,下面是我列出来的解决方案,分享给大家。

下面是内存溢出 jb51.cc 通过网络收集整理的代码片段。内存溢出小编现在分享给大家,也给大家做个参考。

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

方法一

<HTML>

<head>

<style>

body {margin-left: 0px;margin-top: 0px;margin-right: 0px;margin-bottom: 0px;overflow: hIDden;}

</style>

</head>

<body>

<iframe src="http://www.22vd.com/" wIDth='100%' height='100%' frameborder='0' name="_blank" ID="_blank" ></iframe>

</body>

</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 浏览器,下面是代码部分。

<div >

<iframe scrolling="no" ID="main" name="main" frameborder="0" src="" ></iframe>

</div>

<script>

// 计算页面的实际高度,iframe自适应会用到

function calcPageHeight(doc) {

var cHeight = Math.max(doc.body.clIEntHeight,doc.documentElement.clIEntHeight)

var sHeight = Math.max(doc.body.scrollHeight,doc.documentElement.scrollHeight)

var height = Math.max(cHeight,sHeight)

return height

}

//根据ID获取iframe对象

var ifr = document.getElementByID('main')

ifr.onload = function() {

//解决打开高度太高的页面后再打开高度较小页面滚动条不收缩

ifr.style.height='0px';

var IDoc = ifr.contentdocument || ifr.document

var height = calcPageHeight(IDoc)

if(height < 850){

height = 850;

}

ifr.style.height = height + 'px'

}

</script>

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

以上是内存溢出(jb51.cc)为你收集整理的全部代码内容,希望文章能够帮你解决所遇到的程序开发问题。如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

总结

以上是内存溢出为你收集整理的CSS完美实现iframe高度自适应(支持跨域)全部内容,希望文章能够帮你解决CSS完美实现iframe高度自适应(支持跨域)所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/web/1095954.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-28
下一篇2022-05-28

发表评论

登录后才能评论

评论列表(0条)

    保存