如何在 表设计器中使用带有函数的自定义库?

随着现代技术的高速发展,相关产业所衍生出来的数据集是越来越庞大。那么我们如何能够简单、方便、快捷的展现自己输入数据且能够以我们想要的方式展现出来/span>——这一产物便应运而生,现在市面上流行的 表工具类产品也是层出不穷。

第三方 表工具是数据库存储,数据库程序通常可以存放的数据量是相当大的,可以处理非常复杂的数据结构关系。 表数据交互也快捷方便,速度也非常快,可视化交互渲染。

表设计器中的内置函数库并不是很小,但有时候仍然缺乏一些特定的功能。由于中的脚本,可以轻松实现所需的功能。但是,如果许多记录中需要此功能呢次都将它添加到 表脚本中然不是。可以在连接到 表设计器的库中收集所有需要的函数。需要库与 表位于同一文件夹中,创建一个类库项目,将在其中拥有一个测试函数。例如,将数组转换为字符串的功能,编译库:

namespace ArrayToString{ public static class UserDefined { public static string ArrayToString(List<string> parameters) { return String.Join(",", parameters); } }}

现在创建应用程序,将在其中打开 表生成器并使用我们的库ArrayToString,这是一个正常的Winforms应用程序。将库FastReport添加到项目引用:建议将库存储在与应用程序的可执行文件相同的目录中,所以可以在draft中添加对它的引用。除此之外,库将被添加到编译中包含可执行文件的文件夹中,应用程序中只有表单和按钮,添加按钮单击事件处理程序:

private void RunBtn_Click(object sender, EventArgs e) { Report report = new Report(); report.Design(); } 

运行该应用程序,然后单击按钮, 表设计器将以空 表开头。在 表属性中,可以添加指向.net库的链接。

CustomLib

创建一个简单的 表模板——产品类别列表:

CustomLib

将文本对象添加到页脚页带。转到“Script”选项卡,创建一个列表,将在其中添加类别名称。用户库中的函数将列表转换为一行,在页面的基础中显示该行。所以,创建一个列表:

public class ReportScript { public List<string> list = new List<string>(); }

回到 表页面。对于Data band,创建AfterPrint事件处理程序:

 private void Data1_AfterPrint(object sender, EventArgs e) { list.Add(((String)Report.GetColumnValue("Categories.CategoryName"))); } 

每次显示band“Data”时都会添加类别的名称,现在,为Page Footer band中的文本对象添加BeforePrint事件处理程序:

 private void Text1_BeforePrint(object sender, EventArgs e) { Text1.Text = ArrayToString.UserDefined.ArrayToString(list); } 

为文本对象分配用户定义函数从先前添加的dll返回的字符串。请注意,函数的路径已满,包含命名空间和类名。如果将ArrayToString库添加到使用中,则可以缩短名称。现在可以在预览模式下运行 表,页面顶部:

CustomLib

在页面底部:

CustomLib

在一行中获得了产品类别列表,可以在页面底部的文本对象中使用以下表达式:

  [ArrayToString.UserDefined.ArrayToString(list)]  

相当于:

   private void Text1_BeforePrint(object sender, EventArgs e) { Text1.Text = ArrayToString.UserDefined.ArrayToString(list); }

不需要创建事件处理程序,如果要在Web项目中使用自定义库来生成 表,则需要将其放在bin文件夹中。

如果您对FastReport感兴趣,可以在 免费下载最新试用版,欢迎加入FastReport QQ交流群:702295239

标签:

声明:本站部分文章及图片源自用户投稿,如本站任何资料有侵权请您尽早请联系jinwei@zod.com.cn进行处理,非常感谢!

上一篇 2021年6月3日
下一篇 2021年6月3日

相关推荐

发表回复

登录后才能评论