【同域】根据iframe中引用的网页的高度来修改父级页面的iframe高度-iframe自适应子页高度
2013-12-20 19:49
537 查看
如题。
网上提供了很多方法。但是在进行测试的时候都会出现这样那样的问题。在一个好同学的帮助下,我使用了这种方法来实现了这个功能。
在父级页面iframe元素外部使用一个<div>元素包围住。然后设置<div>的初始高度不需要设置,设置好宽度,然后被包围的iframe的高度宽度均设置为100%;你也可以不用div,直接通过子页中的方法来修改父级页面iframe的高度。
这个方法可以兼容chrome,IE,firefox,safari等主流浏览器。
注意这个函数的必须要在子页面的高度确定之后执行,否则其高度则会出现不完全的效果。我们可以添加一个延时函数来实现延迟加载onload函数。
在父页面调用下面的方法来强行刷新iframe中的子页面。
网上提供了很多方法。但是在进行测试的时候都会出现这样那样的问题。在一个好同学的帮助下,我使用了这种方法来实现了这个功能。
在父级页面iframe元素外部使用一个<div>元素包围住。然后设置<div>的初始高度不需要设置,设置好宽度,然后被包围的iframe的高度宽度均设置为100%;你也可以不用div,直接通过子页中的方法来修改父级页面iframe的高度。
<!--main begin--> <div id="iframeHeight">//注意要在css设置好宽度,高度可放空 <iframe id="carMainBox" name="carMainBox" src="dongguan.html" frameborder="0" width="100%" height="100%" scrolling="no"></iframe> </div> <!--main end-->在被引用的子页中,添加如下的window.inload()函数:
<!--更新外框高度window.load代码--> <script type="text/javascript"> window.onload=function(num){ try{ var s = parent.document.getElementById('iframeHeight')||null; }catch(e){} //是否获取到了div的这个元素,如果获取到了,则设置他的高度为内页高度再加上50px的灵活空间 s?s.style.height = document.body.offsetHeight +50+'px':''; } </script>
这个方法可以兼容chrome,IE,firefox,safari等主流浏览器。
注意这个函数的必须要在子页面的高度确定之后执行,否则其高度则会出现不完全的效果。我们可以添加一个延时函数来实现延迟加载onload函数。
在父页面调用下面的方法来强行刷新iframe中的子页面。
setTimeout(function(){sonPage.window.onload();},500);sonPage会默认get到iframe的里页。然后执行onload函数,500是延时的时长,单位是毫秒。
相关文章推荐
- 父级页面动态适应iframe高度变化
- jQuery简单实现iframe的高度根据页面内容自适应的方法
- jQuery简单实现iframe的高度根据页面内容自适应的方法
- jQuery简单实现iframe的高度根据页面内容自适应的方法
- iframe框架自动适应子页的高度
- JS 中根据iframe子页面自动iframe高度
- Iframe 自动适应页面的高度示例代码
- jsp页面iframe高度自适应的js代码
- js代码保证iframe适应被加载页面的高度
- Iframe 自适应其加载的网页高度(多浏览器兼容版)
- jQuery设置iframe的高度根据页面内容自适应
- 商品详情页面特殊制作,获取网页的高度,collectionView根据内容的变化其高度也随着变化
- 网页根据自身高度动态调整所在iframe的高度
- 最近用到的一些网页知识,根据解析域名做跳转和iframe加载页面
- iframe根据被嵌网页高度动态调整自身高度
- jq_jquer获取iframe的高度根据页面内容自适应
- iframe自适应高度,根据src中页面来得到。
- 用JS控制Iframe自动适应页面的高度
- iframe同域或异域下高度自动适应(兼容种浏览器)
- Iframe 自动适应页面的高度示例代码