反馈已提交

网络繁忙

iframe嵌入报表滚动条问题

  • 文档创建者:文档助手1
  • 历史版本:17
  • 最近更新:Carly 于 2023-06-28
  • 本文方案由番薯提供,提供给具备自主开发能力的用户使用。

    若您的场景方案与文档不完全一致,技术支持不负责文档的维护和使用问题解答。请移步帆软社区提问:问答

    1. 概述

    1.1 问题描述

    用户有时会使用 Web 页面集成 ,在一个网页中嵌入一个 iframe,iframe 中嵌入一张报表。

    当报表大小超过 iframe 大小时,iframe 中就会出现滚动条;

    当 iframe 超过浏览器大小时,浏览器便会出现滚动条,如下图所示:

    222

    出现滚动条原因如下图所示:

    1598597583264442.png

    1.2 实现思路

    本例要让 iframe 始终在浏览器里面,只有报表超出的部分可能会出现滚动条。

    因此有两种方式解决:

    • 使用百分比来定义 iframe 大小

    • 直接隐藏滚动条。

    2. 示例

    2.1 操作步骤

    首先来看 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 则表示没有边框

    因此,如果用实际像素值来定义 iframe 的大小,就可能出现 iframe 比浏览器大的情况。

    2.1.1 使用百分比来定义 iframe 大小

    使用百分比来定义 iframe 大小,确保 iframe 始终在浏览器内,只有 iframe 中才可能会出现滚动条,如下图所示的效果,就只有一组滚动条,示例如下:

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

    2.1.2 直接隐藏滚动条

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

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

    2.1.3 效果展示

    只保留一个滚动条,如下图所示:

    image.png

    2.2 其他问题

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

    <body style="margin:0px">


    附件列表


    主题: 部署集成
    • 有帮助
    • 没帮助
    • 只是浏览
    中文(简体)

    鼠标选中内容,快速反馈问题

    鼠标选中存在疑惑的内容,即可快速反馈问题,我们将会跟进处理。

    不再提示

    10s后关闭

    联系我们
    在线支持
    获取专业技术支持,快速帮助您解决问题
    工作日9:00-12:00,13:30-17:30在线
    页面反馈
    针对当前网页的建议、问题反馈
    售前咨询
    采购需求/获取报价/预约演示
    或拨打: 400-811-8890 转1
    qr
    热线电话
    咨询/故障救援热线:400-811-8890转2
    总裁办24H投诉:17312781526
    提交页面反馈
    仅适用于当前网页的意见收集,帆软产品问题请在 问答板块提问前往服务平台 获取技术支持