1. 概述
1.1 预期效果
在决策报表 body 中使用控件查询数据时,若其他组件引用了控件名称作为参数,那么控件在选择查询参数后点击「确定」或点击空白处,会立即触发查询动作。如下图所示:
但有时候希望它不会自动查询,而是通过点击「查询按钮」来触发查询动作。如下图所示:
1.2 解决思路
在控件的「编辑结束」事件里用 return false; 阻止原有的查询效果,然后在查询按钮里用 gotoPage 去刷新报表块并实现传参效果。
注:文本控件需使用「编辑后」事件。
2. 下拉框示例
2.1 准备模板
1)点击设计器左上角「文件>新建决策报表」,新建空白模板。
2)点击顶部菜单栏「模板>PC端自适应属性」,将报表布局设置为「绝对布局」。如下图所示:
2.2 设计报表
1)向 body 中分别拖入标签控件、下拉复选框控件、按钮控件、报表块,调整到合适大小和布局。最终效果如下图所示:
2)本例中「下拉复选框控件」返回值为「数组」,那么给报表块的 A1 单元格添加公式 split($a,",") ,表示返回由逗号分割的字符串数组。再设置「单元格属性>扩展」中的扩展方向为「纵向扩展」,那么下拉框多选时,返回的值可纵向排列展示。
2.3 设置标签控件
选中标签控件,设置控件值为字符串 序列查询: ,如下图所示:
2.4 设置下拉框复选控件
1)选中「下拉复选框控件」,设置控件名称为 a ,数据字典类型为「自定义」。如下图所示:
2)在事件中添加一个编辑结束事件,输入 JavaScript 代码:
return false;
如下图所示:
2.5 设置按钮控件
1)选中按钮控件,将按钮名字修改为「查询」。
注:控件工具栏中的「查询按钮」控件只能在参数面板中使用,所以这里用「按钮控件」来实现查询按钮。
2)添加一个点击事件,输入 JavaScript 代码如下:
var a=_g().getWidgetByName('a').getValue(); // 获取下拉复选框控件 a 的值
_g().getWidgetByName("report0").gotoPage(1,"{a:'"+a+"'}",true); //将 a 的值作为参数传递给 report0 报表块
注1:若需要传递多个参数,gotoPage 写法为 gotoPage(1,"{a:'参数值', b:'参数值'}",true) 。
注2:重新计算模板中所有报表块,对服务器有一定的压力,不适用于高频触发的场景。
注3:若要传参给图表块,可使用接口 changeParameter ,输入 JavaScript 代码如下:
var a=_g().getWidgetByName('a').getValue();
FR.Chart.WebUtils.changeParameter({chartID: 'chart0',para: "{a:'"+a+"'}"})
如下图所示:
2.6 效果预览
保存报表,点击「PC端预览」,效果如 1.1 节预期效果所示。
注:不支持移动端。
3. 复选框联动筛选示例
当下拉复选框的字符串分隔符为',',在使用点击「查询按钮」赋值到对应报表块的传参操作时,参数的数据格式是 json 格式,不支持直接使用 ',' 作为分隔符。因此,参数值无法传入对应的报表单元格,导致无法进行联动筛选。
可以通过更改「下拉复选框>属性>分隔符」和「模板数据集>编辑>参数」实现。
3.1 准备模板
点击设计器左上角「文件>新建决策报表」,新建空白模板。点击顶部菜单栏「模板>PC端自适应属性」,将报表布局设置为「绝对布局」。
3.2 设计报表
1)向 body 中分别拖入标签控件、下拉复选框控件、按钮控件、报表块,调整到合适大小和布局。
2)新建数据集 ds1 , SQL 查询语句为:
SELECT * FROM Air_Accidents
where Regions in('${reg}')
如下图设计表格,将数据集中的字段分别拖拽到对应单元格中。
3.3 设置下拉复选框控件
选中下拉复选框控件,设置控件名称为 ucompany ,数据字典类型为「数据库表」。如下图所示:
3.4 设置按钮控件
选中按钮控件,将按钮名字修改为「查询」,添加一个点击事件,输入 JavaScript 代码如下:
var a = _g().getWidgetByName('ucompany').getValue();
_g().getWidgetByName("report0").gotoPage(1, "{ucompany:'" + a + "'}", true);
如下图所示:
3.5 设置分隔符和数据集参数
选中「下拉复选框控件」,点击顶部菜单栏「属性>返回值类型」,选择「字符串」,将分隔符改成 , 。
点击左侧「模板数据集>编辑」,将数据集传参查询位置改成REPLACE($a,",","','"),将,替换成','。
注:也可将「下拉复选框控件」分隔符改成 |,| 。数据集传参查询位置改成 REPLACE($a,"|,|","','")。或将「下拉复选框控件」分隔符改成 "," 。数据集传参查询位置改成 REPLACE($a,"\",\"","','")。
3.6 效果预览