iframe嵌入报表滚动条问题
1. 描述
一个网页中嵌入了一个iframe,iframe中嵌入一张报表,当报表大小超过iframe大小时,iframe中就会出现滚动条;
当iframe超过浏览器大小时,浏览器便会出现滚动条,就是下图这种效果。
2. 实现原理
如果我们横向与纵向都只想保留一个滚动条,应该怎么做呢?首先我们来看一下iframe的定义方式:
<iframe id="xx" name="xx" src="xx" height=100% width=100% frameborder="0"></iframe>
其中height、width决定了iframe的大小,其值有两种写法:
height=100%相对于浏览器的百分比
height="800"实际像素值
frameborder="0"设置HTML框架边框的显示方式,0则表示没有边框
3. 实现步骤
如果用实际像素值来定义iframe的大小,就可能出现iframe比浏览器大的情况。
因此这个问题的解决方法就是,定义iframe大小时使用百分比来定义,这样确保iframe始终在浏览器内,只有iframe中才可能会出现滚动条,如下图所示的效果,就只有一组滚动条了,示例如下:
因此这个问题的解决方法就是,定义iframe大小时使用百分比来定义,这样确保iframe始终在浏览器内,只有iframe中才可能会出现滚动条,如下图所示的效果,就只有一组滚动条了,示例如下:
<iframe id="reportFrame" frameborder=no width="100%" height="100%" src="/WebReport/ReportServer?reportlet=/demo/basic/DetailedDrillA.cpt"></iframe>
也可以直接将滚动条隐藏,js代码如下:
<iframe id="reportFrame" frameborder=no scrolling="no" src="/WebReport/ReportServer?reportlet=/demo/basic/DetailedDrillA.cpt"></iframe>
3.1 其它问题
其中使用谷歌浏览器还是会有滚动条,因为body默认有margin属性,谷歌计算iframe的宽度时去掉margin了,但是计算高度时没去掉,所以页面集成时需要修改body属性,加上style="margin:0px"。
<body style="margin:0px">
附件列表
标签:
已验证
文档内容仅供参考,如果你需要获取更多帮助,付费/准付费客户请咨询帆软技术支持
关于技术问题,您还可以前往帆软社区,点击顶部搜索框旁边的提问按钮
若您还有其他非技术类问题,可以联系帆软传说哥(qq:1745114201)