iframe嵌入报表滚动条问题

编辑
  • 文档创建者:文档助手1
  • 浏览次数:7036次
  • 编辑次数:12次
  • 最近更新:Kevin-s 于 2019-06-09
  • 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 id="reportFrame" frameborder=no width="100%" height="100%" src="/webroot/decision/view/report?viewlet=/demo/basic/DetailedDrillA.cpt"></iframe>

    也可以直接将滚动条隐藏,JS 代码如下:

    <iframe id="reportFrame" frameborder=no scrolling="no" src="/webroot/decision/view/report?viewlet=/demo/basic/DetailedDrillA.cpt"></iframe>



    3.1 其它问题

    其中使用谷歌浏览器还是会有滚动条,因为 body 默认有 margin 属性,谷歌计算 iframe 的宽度时去掉 margin 了,但是计算高度时没去掉,所以页面集成时需要修改 body 属性,加上 style="margin:0px"

    <body style="margin:0px">


    附件列表


    主题: 部署集成
    标签: 暂无标签 编辑/添加标签
    如果您认为本文档还有待完善,请编辑

    文档内容仅供参考,如果你需要获取更多帮助,付费/准付费客户请咨询帆软技术支持
    关于技术问题,您还可以前往帆软社区,点击顶部搜索框旁边的提问按钮
    若您还有其他非技术类问题,可以联系帆软传说哥(qq:1745114201

    此页面有帮助吗?只是浏览 [ 去社区提问 ]