`
caiceclb
  • 浏览: 239367 次
  • 性别: Icon_minigender_1
  • 来自: 郑州
社区版块
存档分类
最新评论

jquery.load()使iframe随内容改变而自适应高度

    博客分类:
  • JEE
阅读更多
很高兴,终于使用jquery实现了点击外部链接,更改iframe内容时,iframe的高度自适应问题。

失败的测试就不说了,来直接的。

两个链接和iframe:

<li><a href="selfinfo.jsp" target="c-c-iframe" title="个人信息" >个人信息</a></li>
<li><a href="modifypass.jsp" target="c-c-iframe" title="修改密码" >修改密码</a></li>

<iframe src="init.jsp" id="c-c-iframe" name="c-c-iframe" width="500px;"  frameborder="0" scrolling="no" marginwidth="0" marginheight="0"></iframe>


js代码:

<script type="text/javascript">
<!--
$(function(){
	$("#c-c-iframe").load(function(){		
		$(this).height($(this).contents().find("#content").height() + 40);
	});
	
});
-->
</script>


这里的find("#content")是找出iframe内容文档中的id为content的高度(另外比如find("body")),并设置给iframe,
类似的还可以设置宽度,留给需要的朋友尝试吧。

这样就解决了iframe不会因为内容过大被挡住的问题(因为我设置了scrolling="no")。


PS:基本上我会优先考虑使用iframe来实现无刷新,兼容浏览器的后退按钮;而且使用iframe加载flash是很爽的,不用写什么js调用,object标签,还符合W3C标准。

2008年11月28日17:13:31 ,今天使用过程中根据实际情况进行了一下改良,代码如下:

	<script type="text/javascript">
<!--
$(function(){
	$("#workArea").load(function(){		
		var height = $(this).contents().find("#box").height() + 40;
//这样给以一个最小高度
		$(this).height( height < 400 ? 400 : height );
	});
	
});
-->
</script>


另发现使用find("body")不太好使,高度不准确。
分享到:
评论
4 楼 liuweihug 2014-04-11  
iframe自适应高度并解决jquery ajax获取数据后高度自适应问题 
http://www.suchso.com/projecteactual/jquery-ajax-iframe-resetiframeheight.html
3 楼 ehow 2009-11-16  
对ie7好像有效
2 楼 caiceclb 2009-06-25  
用iframe加载flash是有兼容问题,不被动态的层遮盖
1 楼 dzz1001 2009-03-18  
对ie好像无效.

相关推荐

Global site tag (gtag.js) - Google Analytics