1. 概述
1.1 预期效果
当使用的数据来自文件数据集、内置数据集时,无法通过 SQL 语句来实现下拉复选框的参数联动,就需要通过设置公式来实现参数联动。联动效果如下图所示:
1.2 实现思路
使用公式来实现下拉框的参数联动,公式通常为数据集函数,如何使用可参考 :数据集函数
2. 示例
2.1 准备数据
新建普通报表,新建一个内置数据集Embedded1 ,如下图所示:
2.2 添加模板参数
点击菜单栏「模板>模板参数」,新建两个模板参数「产品类型」和「产品」,如下图所示:
2.3 添加控件
编辑参数面板,选择全部添加,并且设置控件类型为下拉复选框控件,如下图所示:
2.4 设置数据字典
1)选中产品类型控件,选择「控件设置>属性>数据字典」,类型设置为数据查询,数据集为Embedded1,实际值和显示值为产品类型。如下图所示:
2)选中产品控件,选择「控件设置>属性>数据字典」,类型设置为公式,其中实际值处设置为 if(len($产品类型)=0,Embedded1.select(产品),eval("Embedded1.select(产品,inarray(产品类型,['"+joinarray($产品类型,"','")+"'])>0)"))
公式说明:
公式 | 说明 |
---|---|
len($产品类型) | 得到产品类型参数值的长度 |
Embedded1.select(产品) | 获取 Embedded1 数据集的产品列,函数使用可查看 数据集函数概述 |
joinarray($产品类型,"','") | 将产品类型数组转换成一个以 ',' 为分隔符的字符串,函数使用可查看 数组函数概述 |
eval("Embedded1.select(产品,inarray(产品类型,['"+joinarray($产品类型,"','")+"'])>0)") | 将"Embedded1.select(产品,inarray(产品类型,['"+joinarray($产品类型,"','")+"'])>0)" 以公式结果输出,其中作用为获取 Embedded1 数据集的产品列,过滤条件产品类型为产品类型参数的值,函数使用可查看 其他函数概述 |
if(len($产品类型)=0,Embedded1.select(产品),eval("Embedded1.select(产品,inarray(产品类型,['"+joinarray($产品类型,"','")+"'])>0)")) | 做一个判断,当产品类型参数无值是,返回所有产品列,否则返回输入的产品类型对应的产品列 |
显示值处空白即可,如下图所示:
2.5 设计报表样式
报表设计样式如下图所示,将 A2 单元格扩展方式选择「列表」。
2.6 设置过滤条件
1)双击 A2 单元格,选择过滤,设置可选列为产品类型,操作符为等于,参数为产品类型,点击增加,如下图所示:
2)选择过滤,设置可选列为产品,操作符为等于,参数为产品,点击增加,再次为 A2 单元格添加一个过滤条件。如下图所示:
2.7 效果预览
2.7.1 PC 端
保存模板,点击「分页预览」,效果如 1.1 节所示。
2.7.2 移动端
App 和 HTML5 端效果相同,如下图所示:
3. 模板下载
已完成模板可参见:%FR_HOME%\webroot\WEB-INF\reportlets\doc\Parameter\公式实现下拉框参数联动.cpt
点击下载模板:公式实现下拉复选框参数联动.cpt