历史版本10 :根据下拉复选框选中个数返回不同值 返回文档
编辑时间: 内容长度:图片数:目录数: 修改原因:

目录:

1. 概述编辑

1.1 版本

报表服务器版本
功能变更
11.0--

1.2 预期效果

下拉复选框可选择一个、多个或全选,希望根据选择的个数返回不同的值。

例如:下拉复选框中选择一个时返回值为「单选」,全选时返回值为「全选」,多选但不是全选时返回值为「多选」。如下图所示:


9.gif

1.3 实现思路

获取到下拉复选框个数,然后通过 if 公式判断相对应的值。

2. 下拉复选框返回值类型为字符串编辑

2.1 模板准备

1)新建普通报表,在参数面板中添加「下拉复选框控件」和「查询控件」,如下图所示:

10.png

2)点击「模板>模板参数」,添加模板参数「p1」,如下图所示:

1598931555543094.png

2.2 设置数据字典

选中「下拉复选框控件」,控件名称为 p1 ,数据字典如下图所示:

image.png

2.3 选择返回值类型

选中下拉复选框控件,返回值类型选择「字符串」,分隔符为「逗号」。如下图所示:

13.png

2.4 单元格输入公式

进入设计界面,在 A1 单元格中输入公式:

if(count(split($p1,","))=1,"单选",if(count(split($p1, ","))=6,"全选","多选"))

公式介绍:

  • split($p1, ","):把字符串先转换成数组。

  • count(split($p1, ",")):汇总选中的个数。

  • if(count(split($p1,","))=1,"单选",if(count(split($p1, ","))=6,"全选","多选")):下拉复选框中选择一个时返回值为单选 ,全选时返回值为全选 ,多选但不是全选时返回值为多选

如下图所示:

1601207133753543.png

2.5 效果查看

2.5.1 PC 端

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

2.5.2 移动端

App 及 HTML5 端效果如下图所示:

12.gif

2.6 已完成模板

已完成模板可参见:%FR_HOME%\webapps\webroot\WEB-INF\reportletsoc\Parameter\下拉复选框返回值类型为字符串.cpt

点击下载模板:下拉复选框返回值类型为字符串.cpt

3. 下拉复选框返回值类型为数组编辑

3.1 模板准备

请参见本文 3.1、3.2 节内容。

3.2 选择返回值类型

选中下拉复选框控件,返回值类型选择「数组」。如下图所示:

15.png

3.3 单元格输入公式

进入设计界面,在 A1 单元格中输入公式:

if(count($p1)=1,"单选",if(count($p1)=6,"全选","多选"))

count($p1):汇总选中的个数。

如下图所示:

8.png

3.4 效果查看

效果与本文 3.5 节效果相同。

3.5 已完成模板

已完成模板可参见:%FR_HOME%\webapps\webroot\WEB-INF\reportletsoc\Parameter\下拉复选框返回值类型为数组.cpt

点击下载模板:下拉复选框返回值类型为数组.cpt