没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
原创|使用教程|编辑:凌霄汉|2022-04-15 15:44:43.833|阅读 386 次
概述:本篇文章将为大家带来如何将初步数据输入表格的交互式报告。
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
如您所知,FastReport.NET 报表可以具有在生成报表之前显示的对话框表单。它们允许您设置一些文本、布尔值或数字变量。这些可以是文本字段、表格、列表、下拉列表、日期、复选框,甚至是带有复选框的列表。
通常,对话框表单用于过滤报表中的数据或选择报表行为的标准。但是今天我们将讨论对话形式的另一种可能用途。
让我们看一下需要在显示之前为报表输入数据的情况。当涉及到单个文本字段、复选框、列表时,这是一个简单的案例。但是,如果您有一个数据表,并且想要在构建报告之前手动调整它怎么办?
这是 Grid 网格 组件可以提供帮助的地方。这是一个包含数据的表格,我们可以在构建报告之前在对话框中显示这些数据。
让我们在报表中添加一个对话框窗体并在其上放置一个 Grid 控件。让我们通过右键单击来调用它的上下文菜单:
选择“编辑列...”以将列添加到表中。
在列编辑窗口中添加三列 - 姓名、地址、电话。查看Customers.Name 属性。在这里,我们引用了尚未在报告中的客户数据源。但我们稍后会使用脚本添加它。对于其余列,您需要设置适当的属性。
报告页面模板非常简单——只有一个三列的 Table 对象。我们将把它填充到报告脚本中。
现在,让我们为报表添加 StartReport 事件处理程序:
报告脚本:
public class ReportScript { //Data structure for table public class Customer { public string Name {get; set; } public string Address {get; set; } public string Phone {get; set; } public Customer(string name, string address, string phone) { Name = name; Address = address; Phone = phone; } } private void _StartReport(object sender, EventArgs e) { //List of customers Listcustomers = new List(); //Fill the list of customers with default data customers.Add(new Customer("Kevin Smith", "221 52nd st, Brooklyn, NY, United States", "+12127599755")); customers.Add(new Customer("Justin Ford", "1556 Broadway, suite 416, NY, United States", "+12145678900")); customers.Add(new Customer("Amanda Stephenson", "455 Larkspur Dr., CA, United States", "+14105175379")); // Register the data source in a report Report.RegisterData(customers, "Customers"); //Set the data source in the table Grid1.DataSource = Report.GetDataSource("Customers"); //Set fields in cells Cell6.Text = "[Customers.Name]"; Cell7.Text = "[Customers.Address]"; Cell8.Text = "[Customers.Phone]"; } }
在这种情况下,我们设置了将用于在对话框和报表中显示表中的行的 Customer 数据结构。接下来,我们创建一个客户数据源并使用客户实例填充它。然后我们在报表中注册接收到的数据源。你还记得我们是如何为 Grid 对象中的列设置数据字段的吗?我们提到了这个数据源。在这里,我们将源中的字段分配给页面模板中的表格单元格(表格对象)。
现在让我们为报表页面上的 Table 对象创建一个 ManualBuild 事件处理程序。在页面上构建对象后调用此事件,并允许您更改准备显示的表格。因此,我们可以使用脚本更改表格中的文本。
private void Table1_ManualBuild(object sender, EventArgs e) { //Set the data source DataSourceBase rowData = Report.GetDataSource("Customers"); //Initialize the data rowData.Init(); //Display the first row of data Table1.PrintRow(0); //Display the column Table1.PrintColumns(); //Loop through all rows of data in source while (rowData.HasMoreRows) { //Output the next line of data Table1.PrintRow(1); //Output the column Table1.PrintColumns(); //take the following entry from the source rowData.Next(); } }
在这里,我们通过简单地遍历所有数据行来填充表格。
让我们运行报告。我们将看到的第一件事是一个带有表格的对话框:
让我们双击第一个单元格来编辑它的文本:
单击确定并检查结果:
如您所见,我们的默认数据已更改为我们手动输入的数据。通过这种方式,您可以让用户在构建报表之前手动更改数据。此示例显示如何使用来自脚本的数据填充表,但没有什么能阻止您使用来自源的数据填充它。
FastReport 技术交流群:702295239 欢迎一起进群讨论
更多FastReport线上公开课、中文教程资讯请上中文网获取
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com
从 2025.2 版本开始,用于仪表板创建的 Stimulsoft 产品引入了InclusionMode属性,我们将在本文中对其进行探讨。
本文将为大家介绍如何在Telerik UI for WinForms应用中使用Kendo UI for Angular组件来交换通信和事件,欢迎下载新版组件体验!
本教程提供DevExpress WinFormsWinExplorer视图的基本信息,欢迎下载最新版组件体验!
在许多企业应用程序中,从 Visio 文件读取形状数据是一项常见需求,因为这些应用程序中的图表都包含有意义的元数据。本教程将借助Aspose.Diagram,以清晰实用的方式指导您使用 C# 读取形状数据。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@evget.com
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢
慧都科技 版权所有 Copyright 2003-
2025 渝ICP备12000582号-13 渝公网安备
50010702500608号