Chinaunix首页 | 论坛 | 博客
  • 博客访问: 200673
  • 博文数量: 97
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1024
  • 用 户 组: 普通用户
  • 注册时间: 2014-04-03 09:03
文章分类
文章存档

2017年(17)

2016年(54)

2015年(25)

2014年(1)

我的朋友

分类: Web开发

2016-11-24 17:02:46

在使用报表软件时,用户系统左边一般有目录树,点击报表节点就会在右侧网页的iframe中显示出报表,同时点击的时候也会传递一些参数给网页,比如时间和用户信息等。如何使网页中的报表能够获取到传递过来的参数呢?以下用报表软件FineReport简单介绍一些。

具体实现过程

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

点击(此处)折叠或打开

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

将代码保存为geturlpara.html,保存在工程下的page_demo文件夹下。

使用管理员登录决策平台,点击管理系统>报表管理,点击添加链接,链接路径为:page_demo/geturlpara.html?report=doc/Parameter/MultiValue/MultiValue.cpt&area=华东&province=江苏&city=无锡,名称为:url参数传递给iframe中的报表,如下图:

 

这样刷新fs,就可以看到左侧目录树中多了一个节点,点击该节点后,就可以在右侧网页的iframe中显示出报表包括传递给网页的参数。

效果查看

如下图,点击左侧“url参数传给iframe中的报表”节点时,即打开相对应的链接,对应网页就会在中间区域显示出来:

 

阅读(4032) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~