【FastReport教程】如何在 表设计器中使用带有函数的自定义库

【FastReport教程】如何在 表设计器中使用带有函数的自定义库

【下载FastReport.Net最新版本】

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

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文件夹中。

标签: 表FastReportFastReport .net

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

上一篇 2018年8月9日
下一篇 2018年8月9日

相关推荐

发表回复

登录后才能评论