反馈已提交

网络繁忙

决策报表控件实现点击查询按钮后才能查询

  • 文档创建者:星踪
  • 历史版本:7
  • 最近更新:Carly 于 2022-07-26
  • 1. 概述

    1.1 预期效果

    在决策报表 body 中使用控件查询数据时,若其他组件引用了控件名称作为参数,那么控件在选择查询参数后点击「确定」或点击空白处,会立即触发查询动作。如下图所示:

    DCC4B849-D301-4CEC-B4C0-0D5DE1CB239D.GIF

    但有时候希望它不会自动查询,而是通过点击「查询按钮」来触发查询动作。如下图所示:

    A4808C25-41F3-462D-B3C5-08640667910C.GIF

    1.2 解决思路

    在控件的「编辑结束」事件里用 return false; 阻止原有的查询效果,然后在查询按钮里用 gotopage 去刷新报表块并实现传参效果。

    2. 示例

    2.1 准备模板

    1)点击设计器左上角「文件>新建决策报表」,新建空白模板。

    2)点击顶部菜单栏「模板>PC端自适应属性」,将报表布局设置为「绝对布局」。如下图所示:

    Snag_7b38a206.png

    2.2 设计报表

    2.2.1 拖入组件

    向 body 中分别拖入标签控件、下拉复选框控件、按钮控件、报表块,调整到合适大小和布局。最终效果如下图所示:

    Snag_7b3e628f.png

    2.2.2 设置标签控件

    选中标签控件,设置控件值为字符串 序列查询: ,如下图所示:

    Snag_7b4089e3.png

    2.2.3 设置下拉框复选控件

    1)选中下拉复选框控件,设置控件名称为 a ,数据字典类型为「自定义」。如下图所示:

    Snag_7b44b6cc.png

    2)在事件中添加一个编辑结束事件,输入 JavaScript 代码:

    return false;

    如下图所示:

    Snag_7b71e9b8.png

    2.2.4 设置按钮控件

    1)选中按钮控件,将按钮名字修改为「查询」。

    注:控件工具栏中的「查询按钮」控件只能在参数面板中使用,所以这里用「按钮控件」来实现查询按钮。

    Snag_7b6b691c.png

    2)添加一个点击事件,输入 JavaScript 代码如下:

    var a=_g().getWidgetByName('a').getValue();  // 获取下拉复选框控件 a 的值
    _g().getWidgetByName("report0").gotoPage(1,"{a:'"+a+"'}",true);  //将 a 的值作为参数传递给 report0 报表块

    如下图所示:

    Snag_7b735435.png

    2.2.5 设置报表块

    本例中下拉复选框控件返回值为「数组」,那么给报表块的 A1 单元格添加公式 split($a,",") ,表示返回由逗号分割的字符串数组。再设置「单元格属性>扩展」中的扩展方向为「纵向扩展」,那么下拉框多选时,返回的值可纵向排列展示。

    Snag_7b81c5b8.png

    2.3 效果预览

    保存报表,点击「PC端预览」,效果如 1.1 节预期效果所示。

    注:不支持移动端。

    3. 模板下载

    已完成模板可参见:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\frm\决策报表控件实现点击查询按钮后才能查询.frm

    点击下载模板:决策报表控件实现点击查询按钮后才能查询.frm

    附件列表


    主题: 决策报表应用
    • 有帮助
    • 没帮助
    • 只是浏览

    售前咨询电话

    400-811-8890转1

    在线技术支持

    请前往「服务平台」,选择「在线支持」

    热线电话:400-811-8890转2

    总裁办24H投诉

    热线电话:173-1278-1526

    文 档反 馈

    鼠标选中内容,快速反馈问题

    鼠标选中存在疑惑的内容,即可快速反馈问题,我们将会跟进处理。

    不再提示

    10s后关闭