历史版本8 :URL参数传递给iframe中的报表 返回文档
编辑时间: 内容长度:图片数:目录数: 修改原因:

目录:

1. 概述编辑

1.1 问题描述

决策系统目录页面显示的是报表节点,点击报表节点就会在右侧网页的 iframe 中显示出报表,在点击该节点的时候也会传递一些参数给网页,比如时间和用户信息等。现在希望 iframe 中的报表能够获取到主页面中传递过来的参数,直接填入报表预览页面中。

例如:实现点击网页链接help/page_demo/geturlpara.html?report=doc/Parameter/MultiValue/MultiValue.cpt&area=华东&province=江苏&city=无锡,报表可以直接获取并填入这些参数:

Snag_387a30d0.png

1.2 实现思路

点击报表节点打开一个网页,网页对应的 URL 如:/工程名/xxx.html?para=paravalue,在网页加载时先通过 JS 获取 URL 中的参数值,嫁接在 iframe 的 src 后,形成最终的报表路径。

2. 示例编辑

2.1 制作HTML文件

制作 HTML 文件,代码如下所示,并将该文件放到设计器安装路径%FR_HOME%/webapps/webroot/help/page_demo/geturlpara.html下。

将报表生成网页时,给网页添加 onload 事件,首先获取 URL 中的参数,然后嫁接到 iframe 的 src 上,或者通过获得的参数拼接出完整的报表 URL 赋给 iframe 的 src。

HTML 代码:

<html>
<head>
<title>FineReport Demo</title>
<meta http-equiv="Content-Type" content="text/html; charset=GBK">
<script type="text/javascript" src="/webroot/decision/view/report?op=emb&resource=finereport.js"></script>
<script type="text/javascript">
function autoLoad(){
//返回从问号 (?) 开始的 URL(查询部分)
var paraString = location.search;   
//多个参数用&分隔,将参数字符串转为数组,使每个参数值存于一个数组元素中
var paras = paraString.split("&");  
//每个数组元素中"="后面的值即参数值
var reportName = paras[0].substr(paras[0].indexOf("=") + 1); 
var area = paras[1].substr(paras[1].indexOf("=") + 1);
var province = paras[2].substr(paras[2].indexOf("=") + 1);
var city = paras[3].substr(paras[3].indexOf("=") + 1);
//使用获取的参数值拼接出最终的url
var reportURL = "/webroot/decision/view/report?viewlet=" + reportName + "&area=" + area + "&province=" + province + "&city=" + city;
//URL 中可能包含中文或特殊字符因此需要进行编码转换,注意需要先引入 finereport.js
reportURL = encodeURI(reportURL);
//将新的报表路径赋给报表所在 iframe 的 src
document.getElementById("reportFrame").src = reportURL; 
}
//加载网页时调用autoLoad方法
window.onload = autoLoad;
</script>
</head>
<body>
<iframe id="reportFrame" width="900" height="400"></iframe>
</body>
</html>

2.2 决策系统添加链接

决策系统选择管理系统>目录管理>管理目录>添加链接,新增一个链接形式的报表节点。

链接路径为:help/page_demo/geturlpara.html?report=doc/Parameter/MultiValue/MultiValue.cpt&area=华东&province=江苏&city=无锡

Snag_38841f2c.png

2.3 效果查看

点击新生成的报表节点后,链接路径中的参数就传递到报表中了。

Snag_388ca3e5.png