1、实现思路对照填报界面的自动匹配章节,在参数界面也用sql语句实现一一对应,当第一次打开模板时,标签不显示可以通过js控制实现。
2、描述实现选择客户名称,客户的相应信息在参数面板上展示,查询前,只显示客户名称的下拉框控件,其他的不显示,点击查询后,报表展示该客户的订单信息,如下图:
3、新建模板新建模板数据集即数据库查询,SQL语句为SELECT * FROM [订单]。定义模板参数id:模板>模板参数,添加一个模板参数id。
4、参数面板设计参数对应的控件设置添加参数id生成的控件,控件类型为下拉框皮薹匆热控件,id标签改名为:客户名称。下拉框控件的数据字典设置如下:联动控件的设就女蒿鸳置此处,将客户详细信息显示在参数面板上,以标签控件来展示。增加2个新的标签,其中一个固定标签的控件名设置name,控件值为联系人姓名,另外一个动态标签的控件值为公式:sql("FRDemo", "select 联系人姓名 from 客户 where 客户ID='" + $id +"'", 1, 1),如下:同理,设置好联系人职务,地址和电话号码等标签的设置,完成之后,参数面板如下:标签不可见设置由于要实现在打开模板时,只显示下拉框,其余的标签不显示,那么就需要将所有固定标签设置为不可见,即属性>基本属性>可见,将勾去掉即可;同时,在编辑下拉框之后,参数面板上的标签又需要显示出来,则可以在下拉框控件处添加一个编辑后事件,代码如下:vara=this.options.form.getWidgetByName("name");a.setVisible(true);注:代码中的name是固定标签的控件名,由于要控制多个固定标签,则需要重复写多个这段代码,只是控件名需要一一对应,设置好的参数面板如下:
5、报表主体设计如下图:在A2单元格处设置模板参数的过滤。
6、保存于预览将该模板保存之后,点击分页预览就会看到如上的效果。在线查看模板效果请点击ParaConnection2.cp已完成的模板,可参照:%FR_HOME%\WebReport\WEB-INF\reportlets\doc\Parameter\ParaConnection2.cpt。