Java开发报表——Grid++Report 报表设计器

          为了让数据显示的更加形象生动,报表在项目中几乎是非常常见的,但是大致可以分为两类:


         ,图形:以图形的形式显示数据,例如柱状图,折线图,饼形图等等,这里有很多关于这方面的工具,例如JFreeCharts(利用Java语言实现的,相对来说不是太美观),FunsionChartsFree(利用xml+flash+Js实现,相对来说不错),可以参考我以前的文章:图形生成工具(funsionChartsFree and ifreeChart) ;其次还有HighChartshttp://www.hcharts.cn/demo/index.php)和Echarts(官网:http://echarts.baidu.com/doc/example.html),两者都是通过JS来实现的,是比较推荐使用的。官网的资料非常丰富的

   

       二,就是表格,一种是可以将数据导出为Excel表格,我们可以通过POI(功能更加强大丰富,但是复杂)JXL(简单易用,但是复杂的功能有些实现不了);二,一些统计表格,用于统计重要信息进行打印的。Java中一般常用的JasperReport+iReport,这个网上资料比较多,我们项目使用了Grid++Report,这个报表设计器,支持C/S开发:VB.NET、C#、VB、VC、Delphi等,B/S开发:ASP.NET、ASP、PHP、JSP等,支持所有WEB服务器,以前在C/SVB开发中使用过(报表从陌生到使用 ),这次在Java web中使用了,主要是通过参考用户手册,和官方的demo进行设计的。

    

         用报表设计器设计报表这里不再赘述,无在乎页眉页脚,报表头报表尾,明细网格还有各种部件的使用而已。下边简单看一个报表例子;


         1,首先需要将设计好的grf的报表放到项目的某个路径下,在jsp页面中进行引用:

	<script type="text/javascript">
		// var Installed = Install_Detect();
			CreateDisplayViewerEx("100%", "80%",
					"${contextPath}/assets/gridReport/grf/selfGetNumber.grf", "",
					true, "");		

</script

        这段代码需要body里边,grid++report的默认容器是在body中。


        2,利用AJAX进行数据的访问:

	<script type="text/javascript">
		function getGridData() {
	
			AjaxReportViewerStart(ReportViewer,
					"${contextPath}/log/logregistration/gridData?startTime='2014-10-12'&endTime='2014-10-09'");
	
		}

</script>

            3 AJAX 数据的传输格式规定:

<report>
<xml>
<row><CustomerID>BLONP</CustomerID><CompanyName>国皓</CompanyName><ContactName>黄雅玲</ContactName></row>
<row><CustomerID>CACTU</CustomerID><CompanyName>威航货运有限公司</CompanyName><ContactName>刘先生</ContactName></row>
<row><CustomerID>CENTC</CustomerID><CompanyName>三捷实业</CompanyName><ContactName>王先生</ContactName></row>
<row><CustomerID>HUNGC</CustomerID><CompanyName>五金机械</CompanyName><ContactName>苏先生</ContactName></row>
<row><CustomerID>MEREP</CustomerID><CompanyName>华科</CompanyName><ContactName>吴小姐</ContactName></row>
</xml>
<_grparam>
<Parameter1>Value1</Parameter1>
<Parameter2>Value2</Parameter2>
<StaticBox1>Text1</StaticBox1>
<MemoBox1>Text2</MemoBox1>
</_grparam>
</report>

      其中row为明细表格中字段,_grparam为参数。这里需要注意的是字段名字的对应。只要我们在后台用PrintWriter进行write我们拼接好的xml字符串即可。

 

        当然我这里只是一个简单的例子,其实报表开发都差不多,需要我们多看看文档,看看官方的例子就好多了。




你可能感兴趣的:(设计,报表,work,Grid++Report)