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

相关文章

nginx负载均衡及详细配置方法

《nginx负载均衡及详细配置方法》Nginx作为一种高效的Web服务器和反向代理服务器,广泛应用于网站的负载均衡中,:本文主要介绍nginx负载均衡及详细配置,需要的朋友可以参考下... 目录一、 nginx负载均衡策略1.1 基本负载均衡策略1.2 第三方策略1.3 策略对比二、 nginx配置2.1

Java调用Python的四种方法小结

《Java调用Python的四种方法小结》在现代开发中,结合不同编程语言的优势往往能达到事半功倍的效果,本文将详细介绍四种在Java中调用Python的方法,并推荐一种最常用且实用的方法,希望对大家有... 目录一、在Java类中直接执行python语句二、在Java中直接调用Python脚本三、使用Run

使用Python开发Markdown兼容公式格式转换工具

《使用Python开发Markdown兼容公式格式转换工具》在技术写作中我们经常遇到公式格式问题,例如MathML无法显示,LaTeX格式错乱等,所以本文我们将使用Python开发Markdown兼容... 目录一、工具背景二、环境配置(Windows 10/11)1. 创建conda环境2. 获取XSLT

Python中Flask模板的使用与高级技巧详解

《Python中Flask模板的使用与高级技巧详解》在Web开发中,直接将HTML代码写在Python文件中会导致诸多问题,Flask内置了Jinja2模板引擎,完美解决了这些问题,下面我们就来看看F... 目录一、模板渲染基础1.1 为什么需要模板引擎1.2 第一个模板渲染示例1.3 模板渲染原理二、模板

浅析如何使用xstream实现javaBean与xml互转

《浅析如何使用xstream实现javaBean与xml互转》XStream是一个用于将Java对象与XML之间进行转换的库,它非常简单易用,下面将详细介绍如何使用XStream实现JavaBean与... 目录1. 引入依赖2. 定义 JavaBean3. JavaBean 转 XML4. XML 转 J

Android 12解决push framework.jar无法开机的方法小结

《Android12解决pushframework.jar无法开机的方法小结》:本文主要介绍在Android12中解决pushframework.jar无法开机的方法,包括编译指令、框架层和s... 目录1. android 编译指令1.1 framework层的编译指令1.2 替换framework.ja

使用Python创建一个功能完整的Windows风格计算器程序

《使用Python创建一个功能完整的Windows风格计算器程序》:本文主要介绍如何使用Python和Tkinter创建一个功能完整的Windows风格计算器程序,包括基本运算、高级科学计算(如三... 目录python实现Windows系统计算器程序(含高级功能)1. 使用Tkinter实现基础计算器2.

在.NET平台使用C#为PDF添加各种类型的表单域的方法

《在.NET平台使用C#为PDF添加各种类型的表单域的方法》在日常办公系统开发中,涉及PDF处理相关的开发时,生成可填写的PDF表单是一种常见需求,与静态PDF不同,带有**表单域的文档支持用户直接在... 目录引言使用 PdfTextBoxField 添加文本输入域使用 PdfComboBoxField

SQLyog中DELIMITER执行存储过程时出现前置缩进问题的解决方法

《SQLyog中DELIMITER执行存储过程时出现前置缩进问题的解决方法》在SQLyog中执行存储过程时出现的前置缩进问题,实际上反映了SQLyog对SQL语句解析的一个特殊行为,本文给大家介绍了详... 目录问题根源正确写法示例永久解决方案为什么命令行不受影响?最佳实践建议问题根源SQLyog的语句分

Git可视化管理工具(SourceTree)使用操作大全经典

《Git可视化管理工具(SourceTree)使用操作大全经典》本文详细介绍了SourceTree作为Git可视化管理工具的常用操作,包括连接远程仓库、添加SSH密钥、克隆仓库、设置默认项目目录、代码... 目录前言:连接Gitee or github,获取代码:在SourceTree中添加SSH密钥:Cl