finereport决策报表添加滚动条,实现上下滚动效果

1. 描述

一个网页中嵌入了一个 iframe,iframe 中嵌入一张报表,当报表大小超过 iframe 大小时,iframe 中就会出现滚动条;

当 iframe 超过浏览器大小时,浏览器便会出现滚动条,就是下图这种效果。


https://help.finereport.com/uploads/201808/20180823112010_1632.png

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>

https://help.finereport.com/uploads/201808/20180823112010_2428.png

3.1 其它问题

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

<body style="margin:0px">

1. 描述

一个网页中嵌入了一个 iframe,iframe 中嵌入一张报表,当报表大小超过 iframe 大小时,iframe 中就会出现滚动条;

当 iframe 超过浏览器大小时,浏览器便会出现滚动条,就是下图这种效果。


https://help.finereport.com/uploads/201808/20180823112010_1632.png

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>

https://help.finereport.com/uploads/201808/20180823112010_2428.png

3.1 其它问题

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

<body style="margin:0px">

 

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值