最新历史版本 :公式实现下拉复选框参数联动 返回文档
编辑时间: 内容长度:图片数:目录数: 修改原因:

目录:

1. 概述编辑

1.1 预期效果

当使用的数据来自文件数据集内置数据集时,无法通过 SQL 语句来实现下拉复选框的参数联动,就需要通过设置公式来实现参数联动。联动效果如下图所示:

动画6.gif

1.2 实现思路

使用公式来实现下拉框的参数联动,公式通常为数据集函数,如何使用可参考 :数据集函数

2. 示例编辑

2.1 准备数据

新建普通报表,新建一个内置数据集Embedded1 ,如下图所示:

1.png

2.2 添加模板参数

点击菜单栏「模板>模板参数」,新建两个模板参数「产品类型」和「产品」,如下图所示:

2.png

2.3 添加控件

编辑参数面板,选择全部添加,并且设置控件类型为下拉复选框控件,如下图所示:

1628649408(1).jpg

2.4 设置数据字典

1)选中产品类型控件,选择「控件设置>属性>数据字典」,类型设置为数据查询,数据集为Embedded1,实际值和显示值为产品类型。如下图所示:

2021-08-11_10-41-26.png

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)"))做一个判断,当产品类型参数无值是,返回所有产品列,否则返回输入的产品类型对应的产品列

显示值处空白即可,如下图所示:

2021-08-11_10-43-56.png

2.5 设计报表样式

报表设计样式如下图所示,将 A2 单元格扩展方式选择「列表」。

2.6 设置过滤条件

1)双击 A2 单元格,选择过滤,设置可选列为产品类型,操作符为等于,参数为产品类型,点击增加,如下图所示:

2)选择过滤,设置可选列为产品,操作符为等于,参数为产品,点击增加,再次为 A2 单元格添加一个过滤条件。如下图所示:

2.7 效果预览

2.7.1 PC 端

保存模板,点击「分页预览」,效果如 1.1 节所示。

2.7.2 移动端

App 和 HTML5 端效果相同,如下图所示:

动画2.gif

3. 模板下载编辑

已完成模板可参见:%FR_HOME%\webroot\WEB-INF\reportlets\doc\Parameter\公式实现下拉框参数联动.cpt

点击下载模板:公式实现下拉复选框参数联动.cpt