UniGui中使用Grid++Report报表控件子报表获取数据的方法

2023-12-11 19:58

本文主要是介绍UniGui中使用Grid++Report报表控件子报表获取数据的方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Grid++Report是为优秀的报表控件,子报表是其重要功能之一,但Grid++Report提供的网页报表示范主要是以页面为主的,UniGui在Delphi中以快速编写web管理软件著称,但由于资料文档很少,经过摸索,Grid++Report的子报表要在uniGUi中正确获取子报表数据,只能通过Ajax数据回调的方式进行,在uniGUi中对前端Ajax的响应,就要是通过控件的AjaxEvent事件来处理。报表模板的展示部分的HTML代码要放在UniURLFrame控件的HTML属性中。

AjaxEvent事件函数如下:

FormAjaxEvent(Sender: TComponent; EventName: string;  Params: TStrings);

EventName代表浏览器前端传入的事件名称

Params 浏览器前端传入的参数



UniURLFrame中的网页代码:

其中:

{xmlTop10Product}
{xmlProductList}
{xmlTop10Customer}
{xmlCustomer}

这几个地方需要在服务端运行时替换为UniGui可以识别的回调URL地址。

<span style="font-family: Arial, Helvetica, sans-serif;"><head></span>
<title>Web报表(B/S报表)演示 - 子报表,子报表模板集成定义</title><meta http-equiv="Content-Type" content="text/html; charset=utf-8"/><script src="files/CreateControl.js" type="text/javascript"></script><script type="text/javascript">var CustomerReport;
var ProductReport;
var Top10CustomerReport;
var Top10ProductReport;//在网页初始加载时向报表提供数据
function window_onload() {CustomerReport = ReportViewer.Report.ControlByName("srCustomerList").AsSubReport.Report;ProductReport = ReportViewer.Report.ControlByName("srProductList").AsSubReport.Report;Top10CustomerReport = ReportViewer.Report.ControlByName("srTop10Customer").AsSubReport.Report;Top10ProductReport = ReportViewer.Report.ControlByName("srTop10Product").AsSubReport.Report;//关联事件CustomerReport.OnInitialize = OnCustomerInitialize;ProductReport.OnInitialize = OnProductInitialize;Top10CustomerReport.OnInitialize = OnTop10CustomerInitialize;Top10ProductReport.OnInitialize = OnTop10ProductInitialize;//开启报表生成进度条显示
//	ReportViewer.Report.ShowProgressUI = true;//启动运行ReportViewer.Start();
}function OnCustomerInitialize()
{//载入子报表数据CustomerReport.LoadDataFromURL("{xmlCustomer}");
}function OnProductInitialize()
{//载入子报表数据ProductReport.LoadDataFromURL("{xmlProductList}");
}function OnTop10CustomerInitialize()
{//载入子报表数据Top10CustomerReport.LoadDataFromURL("{xmlTop10Customer}");
}function OnTop10ProductInitialize()
{//载入子报表数据Top10ProductReport.LoadDataFromURL("{xmlTop10Product}");
}</script><style type="text/css">html,body {margin:0;height:100%;}</style>
</head>
<body style="margin:0" οnlοad="window_onload()"><script type="text/javascript"> CreatePrintViewerEx("100%", "100%", "files/4a.grf", "", false, "");</script>
</body>

Delphi中Main单元的代码:

unit Main;interfaceusesWindows, Messages, SysUtils, Variants, Classes, Graphics,Controls, Forms, Dialogs, uniGUITypes, uniGUIAbstractClasses,uniGUIClasses, uniGUIRegClasses, uniGUIForm, Data.DB, Datasnap.DBClient,uniToolBar, uniGUIBaseClasses, uniPanel, uniHTMLFrame, uniURLFrame;typeTMainForm = class(TUniForm)UniToolBar1: TUniToolBar;btnClose: TUniToolButton;cdsCDS1: TClientDataSet;UniURLFrame1: TUniURLFrame;procedure UniFormCreate(Sender: TObject);procedure UniFormAjaxEvent(Sender: TComponent; EventName: string;Params: TStrings);procedure btnCloseClick(Sender: TObject);private{ Private declarations }publicprocedure ReplaceTags;{ Public declarations }end;function MainForm: TMainForm;implementation{$R *.dfm}usesuniGUIVars, MainModule, uniGUIApplication;function MainForm: TMainForm;
beginResult := TMainForm(UniMainModule.GetFormInstance(TMainForm));
end;procedure TMainForm.btnCloseClick(Sender: TObject);
beginUniMainModule.Terminate;
end;procedure TMainForm.ReplaceTags;
varS, Sc : string;
beginS:=UniURLFrame1.HTML.Text;Sc:=UniSession.CallbackUrl('subReportData', Self, ['RES', 'xmlCustomer']);S:=StringReplace(S, '{xmlCustomer}', Sc, []);Sc:=UniSession.CallbackUrl('subReportData', Self, ['RES', 'xmlProductList']);S:=StringReplace(S, '{xmlProductList}', Sc, []);Sc:=UniSession.CallbackUrl('subReportData', Self, ['RES', 'xmlTop10Product']);S:=StringReplace(S, '{xmlTop10Product}', Sc, []);Sc:=UniSession.CallbackUrl('subReportData', Self, ['RES', 'xmlTop10Customer']);S:=StringReplace(S, '{xmlTop10Customer}', Sc, []);UniURLFrame1.HTML.Text:=S;end;procedure TMainForm.UniFormAjaxEvent(Sender: TComponent; EventName: string;Params: TStrings);
varst:TStringList;
beginif EventName='subReportData' then   //定义的子报表数据回调事件beginif Params.Values['RES']='xmlCustomer' then  //根据Res参数判断是哪一个子报表请求数据begintryst := TStringList.Create;st.LoadFromFile(ExtractFilePath(Application.ExeName)+'data\xmlCustomer.xml');UniSession.AResponse.ContentText := st.Text;finallyst.Free;end;end;if Params.Values['RES']='xmlProductList' thenbegintryst := TStringList.Create;st.LoadFromFile(ExtractFilePath(Application.ExeName)+'data\xmlProductList.xml');UniSession.AResponse.ContentText := st.Text;finallyst.Free;end;end;if Params.Values['RES']='xmlTop10Product' thenbegintryst := TStringList.Create;st.LoadFromFile(ExtractFilePath(Application.ExeName)+'data\xmlTop10Product.xml');UniSession.AResponse.ContentText := st.Text;finallyst.Free;end;end;if Params.Values['RES']='xmlTop10Customer' thenbegintryst := TStringList.Create;st.LoadFromFile(ExtractFilePath(Application.ExeName)+'data\xmlTop10Customer.xml');//可以修改为实时生成的报表支持的xml格式的文本也行UniSession.AResponse.ContentText := st.Text;finallyst.Free;end;end;end;end;procedure TMainForm.UniFormCreate(Sender: TObject);
beginSelf.ReplaceTags;
end;initializationRegisterAppFormClass(TMainForm);end.


这篇关于UniGui中使用Grid++Report报表控件子报表获取数据的方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/481924

相关文章

python获取指定名字的程序的文件路径的两种方法

《python获取指定名字的程序的文件路径的两种方法》本文主要介绍了python获取指定名字的程序的文件路径的两种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要... 最近在做项目,需要用到给定一个程序名字就可以自动获取到这个程序在Windows系统下的绝对路径,以下

Java使用Javassist动态生成HelloWorld类

《Java使用Javassist动态生成HelloWorld类》Javassist是一个非常强大的字节码操作和定义库,它允许开发者在运行时创建新的类或者修改现有的类,本文将简单介绍如何使用Javass... 目录1. Javassist简介2. 环境准备3. 动态生成HelloWorld类3.1 创建CtC

JavaScript中的高级调试方法全攻略指南

《JavaScript中的高级调试方法全攻略指南》什么是高级JavaScript调试技巧,它比console.log有何优势,如何使用断点调试定位问题,通过本文,我们将深入解答这些问题,带您从理论到实... 目录观点与案例结合观点1观点2观点3观点4观点5高级调试技巧详解实战案例断点调试:定位变量错误性能分

使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解

《使用Python批量将.ncm格式的音频文件转换为.mp3格式的实战详解》本文详细介绍了如何使用Python通过ncmdump工具批量将.ncm音频转换为.mp3的步骤,包括安装、配置ffmpeg环... 目录1. 前言2. 安装 ncmdump3. 实现 .ncm 转 .mp34. 执行过程5. 执行结

Python中 try / except / else / finally 异常处理方法详解

《Python中try/except/else/finally异常处理方法详解》:本文主要介绍Python中try/except/else/finally异常处理方法的相关资料,涵... 目录1. 基本结构2. 各部分的作用tryexceptelsefinally3. 执行流程总结4. 常见用法(1)多个e

Java使用jar命令配置服务器端口的完整指南

《Java使用jar命令配置服务器端口的完整指南》本文将详细介绍如何使用java-jar命令启动应用,并重点讲解如何配置服务器端口,同时提供一个实用的Web工具来简化这一过程,希望对大家有所帮助... 目录1. Java Jar文件简介1.1 什么是Jar文件1.2 创建可执行Jar文件2. 使用java

C#使用Spire.Doc for .NET实现HTML转Word的高效方案

《C#使用Spire.Docfor.NET实现HTML转Word的高效方案》在Web开发中,HTML内容的生成与处理是高频需求,然而,当用户需要将HTML页面或动态生成的HTML字符串转换为Wor... 目录引言一、html转Word的典型场景与挑战二、用 Spire.Doc 实现 HTML 转 Word1

Java中的抽象类与abstract 关键字使用详解

《Java中的抽象类与abstract关键字使用详解》:本文主要介绍Java中的抽象类与abstract关键字使用详解,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录一、抽象类的概念二、使用 abstract2.1 修饰类 => 抽象类2.2 修饰方法 => 抽象方法,没有

MyBatis ParameterHandler的具体使用

《MyBatisParameterHandler的具体使用》本文主要介绍了MyBatisParameterHandler的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参... 目录一、概述二、源码1 关键属性2.setParameters3.TypeHandler1.TypeHa

Spring 中的切面与事务结合使用完整示例

《Spring中的切面与事务结合使用完整示例》本文给大家介绍Spring中的切面与事务结合使用完整示例,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考... 目录 一、前置知识:Spring AOP 与 事务的关系 事务本质上就是一个“切面”二、核心组件三、完