JS实现iframe自适应高度的方法(兼容IE与FireFox)


Posted in Javascript onJune 24, 2016

本文实例讲述了JS实现iframe自适应高度的方法。分享给大家供大家参考,具体如下:

之前一直被iframe自适应高度的问题困扰,很多JS代码在FF里面似乎就变成哑巴了。后来下面这段代码终于被我从万千号称兼容FF的代码堆中翻了出来。我已经用过了,真的好用。尤其是对于我这样的JS水平较低(真不好意思)的人来说,这段代码简单易懂,方便修改,只要把下面的代码复制粘贴到iframe所在页面的<body>标签里面,并且修改一下ID名就行了(注意,要修改的地方有两个,位置在代码中有说明)。

向原创这段代码的朋友致敬。

步骤1:在<body>标签下先输入如下JS代码

<scriptlanguage="javascript">
function adjustFrameSize()
{
  var frm = document.getElementById("iframe1"); //将iframe1替换为你的ID名
  var subWeb = document.frames ? document.frames["iframe1"].document : frm.contentDocument;
  if(frm != null && subWeb !=null)
  {
   frm.style.height="0px";//初始化一下,否则会保留大页面高度
   frm.style.height = subWeb.documentElement.scrollHeight+"px";
   frm.style.width = subWeb.documentElement.scrollWidth+"px";
   subWeb.body.style.overflowX="auto";
   subWeb.body.style.overflowY="auto";
  }
}
</script>

步骤2:在iframe标签中加上id="iframe1"onload="adjustFrameSize()"

例如:

<iframe id="iframe1"onload="adjustFrameSize()" scrolling="no" src="iframe1.html"width="100%" height="300px" target="_self"frameborder="0"></iframe>

这段代码有一个小小的缺点,就是使用后iframe中的内容和外边框(如果存在外边框的话)的距离有点小,可以自己适当调整一下;另外,除IE6.0以上版本和FF以外没有测试过其它浏览器,除此之外尚未发现别的缺陷,如果在使用中发现了问题或者有更好解决方法的童鞋欢迎来分享一下。

如果在iframe页面内部含有ajax加载的页面或者通过js动态去添加内容导致iframe高度变化的情况,可以添加一下方式进行:

1:子页面添加以下内容

//修改父窗口地址
function changeHeight(){
window.top.location.hash = "#height=" + $(document).height();
}

修改dom的部分调用该方法

2:父页面添加

//高度自适应
var iframe = document.getElementById("iframe1");
function iframeHeight() {
  var hash = window.location.hash.slice(1), h;
  if (hash && /height=/.test(hash)) {
    h = hash.replace("height=", "");
    iframe.style.height = h+"px";
    window.location.hash = "#temp";//防止点击其他页面时高度不变
  }
  setTimeout(iframeHeight, 100);
}
iframeHeight();

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
基于jquery的cookie的用法
Jan 10 Javascript
常用jQuery选择器总结
Jul 11 Javascript
javascript常用的方法分享
Jul 01 Javascript
通过网页查看JS源码中汉字显示乱码的解决方法
Oct 26 Javascript
JS中跨页面调用变量和函数的方法(例如a.js 和 b.js中互相调用)
Nov 01 Javascript
微信小程序 this和that详解及简单实例
Feb 13 Javascript
Angular使用Md5加密的解决方法
Sep 16 Javascript
详解Vue组件插槽的使用以及调用组件内的方法
Nov 13 Javascript
JS实现的A*寻路算法详解
Dec 14 Javascript
ES6中定义类和对象的方法示例
Jul 31 Javascript
vue 项目打包时样式及背景图片路径找不到的解决方式
Nov 12 Javascript
原生JavaScript实现简单五子棋游戏
Jun 28 Javascript
AngularJS 路由和模板实例及路由地址简化方法(必看)
Jun 24 #Javascript
老生常谈 关于JavaScript的类的继承
Jun 24 #Javascript
js动态获取子复选项并设计全选及提交的实现方法
Jun 24 #Javascript
EasyUI在表单提交之前进行验证的实例代码
Jun 24 #Javascript
正则表达式(语法篇推荐)
Jun 24 #Javascript
javascript弹出窗口中增加确定取消按钮
Jun 24 #Javascript
javascript类型系统_正则表达式RegExp类型详解
Jun 24 #Javascript
You might like
Discuz!下Memcache缓存实现方法
2010/05/28 PHP
Codeigniter出现错误提示Error with CACHE directory的解决方案
2014/06/12 PHP
php实现过滤字符串中的中文和数字实例
2015/07/29 PHP
php如何获取文件的扩展名
2015/10/28 PHP
Laravel如何实现适合Api的异常处理响应格式
2020/06/14 PHP
jquery delay()介绍及使用指南
2014/09/02 Javascript
全面解析DOM操作和jQuery实现选项移动操作代码分享
2016/06/07 Javascript
Javascript操作表单实例讲解(下)
2016/06/20 Javascript
需灵活掌握的Bootstrap预定义排版类 你精通吗?
2016/06/20 Javascript
Bootstrap模态框禁用空白处点击关闭
2016/10/20 Javascript
Javascript中for循环语句的几种写法总结对比
2017/01/23 Javascript
基于JavaScript实现拖动滑块效果
2017/02/16 Javascript
vue单页开发父子组件传值思路详解
2018/05/18 Javascript
vue2.0学习之axios的封装与vuex介绍
2018/05/28 Javascript
详解webpack模块加载器兼打包工具
2018/09/11 Javascript
p5.js码绘“跳动的小正方形”的实现代码
2019/10/22 Javascript
vue实现标签云效果的示例
2020/11/09 Javascript
Python中文件操作简明介绍
2015/04/13 Python
Python中的匿名函数使用简介
2015/04/27 Python
python套接字流重定向实例汇总
2016/03/03 Python
Python数据类型详解(二)列表
2016/05/08 Python
python数据分析数据标准化及离散化详解
2018/02/26 Python
Python中的二维数组实例(list与numpy.array)
2018/04/13 Python
pytorch使用Variable实现线性回归
2019/05/21 Python
keras:model.compile损失函数的用法
2020/07/01 Python
python drf各类组件的用法和作用
2021/01/12 Python
eBay荷兰购物网站:eBay.nl
2020/06/26 全球购物
天网面试题
2013/04/07 面试题
Shell编程面试题
2016/05/29 面试题
优秀老师事迹材料
2014/02/05 职场文书
汽车专业求职信
2014/06/05 职场文书
部门群众路线教育实践活动对照检查材料思想汇报
2014/10/07 职场文书
党的群众路线批评与自我批评范文
2014/10/16 职场文书
使用nginx配置访问wgcloud的方法
2021/06/26 Servers
idea编译器vue缩进报错问题场景分析
2021/07/04 Vue.js
Linux中各个目录的作用与内容
2022/06/28 Servers