涨姿势、求出处、找福利、找内涵图尽在[飘花福利吧]
> 涨姿势 > 让iframe自适应高度 真正的兼容多种浏览器随着窗口大小改变

让iframe自适应高度 真正的兼容多种浏览器随着窗口大小改变

涨姿势 0评论

今天有朋友问到我关于“iframe自适应高度”的问题,原本以为是很简单的问题,没想到折腾了20分钟才搞定。期间遇到几个问题,要么是高度自适应了,但是当窗口改变时会出现滚动条。也就是当窗口放大时iframe没有自动跟随变大显得很小,或是当窗口缩小时iframe还是之前那么大就出现了滚动条。还有或是高度不准确,那么就达不到想要的效果了。

iframe自适应高度

为什么需要使用iframe自适应高度呢?其实就是为了美观,要不然iframe和窗口长短大小不一,看起来总是不那么舒服,特别是对于我们这些编程的来说,如鲠在喉的感觉。

首先设置样式

body{margin:0; padding:0;}

如果不设置body的margin和padding为0的话,页面上下左右会出现空白。

html代码如下

<iframe src="http://www.phfuli.com" id="myiframe" scrolling="no" frameborder="0"></iframe>

下面就是今天小编写的时候遇到的问题,考虑到有些朋友可能没怎么用jquery就直接用js吧。

方法一

var ifm= document.getElementById("myiframe");
ifm.height=document.documentElement.clientHeight;

这个方法可以达到让iframe自适应高度的效果,但是如果你将窗口放大或缩小效果就不出来了,也就是本文开头讲的。需要再次刷新,那就不属于自适应了。

那么问题来了,需要解决当窗口改变大小的时候执行js事件,以让iframe自适就高度。那么就需要将相关的代码写成函数,并且给iframe加上onLoad="changeFrameHeight()",也就是下面的方法二了。

方法二

<iframe src="http://www.phfuli.com" id="myiframe" scrolling="no" onload="changeFrameHeight()" frameborder="0"></iframe>

js代码也得跟着改

function changeFrameHeight(){
    var ifm= document.getElementById("iframepage");
    ifm.height=document.documentElement.clientHeight;
}
window.onresize=function(){  
     changeFrameHeight();  

window.onresize的作用就是当窗口大小改变的时候会触发这个事件。

所以,使用方法二就可以完美的、真正的让iframe自适应高度了,试试看吧,并且兼容多种浏览器。

飘花福利吧温馨提示:在留言、评论中要求加微信号、QQ群、QQ号的,请朋友们谨慎操作,由此引起的其他问题,飘花福利吧概不负责,请小伙伴们一定要保持清醒的头脑哈!
  • *发表评论:

最新评论

匿名者 11小时前

mum203小西まりえ合演之作中评论 热污染天文沃尔沃二五一

匿名者 12小时前

暗黑版景甜有人知道她的名字吗?中评论 c5210b7eb60a6a7b8eab

匿名者 23小时前

《死侍2》迅雷高清下载度云离线下载观看中评论 看完死侍1就觉得会不会有续集,非常想看看

匿名者 1天前

《死侍2》迅雷高清下载度云离线下载观看中评论 死侍韦德一开场就自己将自己给炸死了,真的

羊城 1天前

[求出处]早乙女由依双马尾萝莉作品id044中评论 富强民主文明和谐自由平等公正法治爱国敬业

匿名者 1天前

葵司dvaj-005,与画家的爱情动作片中评论 求资源,谢谢小编

艾尼森 1天前

259LUXU-881现实将水岛凉香击败所有的高傲都化为乌有中评论 艾尼森,更懂男人心!

匿名者 2天前

白小洁在hunt-938超满员电车上的生活[找福利]中评论 白小洁,这个名字啥含义啊,小编出来走两步

匿名者 2天前

镰田紘子zdad-24 一位拥有绝顶武功的美女护士中评论 很早就看到这个美女,一直不知道是谁,今天

匿名者 3天前

完美护士的不轨行为迅雷下载 穿着护士服出轨偷情中评论 20个字,我都不知道怎么打的出来,嗯,有
登录