Finereport11 类Excel筛选

打印 上一主题 下一主题

主题 656|帖子 656|积分 1968

微信公众号:次世代数据技术
关注可了解更多的教程。题目或建议,请公众号留言或联系本人;
微信号:weibw162
本教程视频解说可以关注本人B站账号举行观看:weibw162
一、需求描述

在利用FIneReport软件开辟时,我们希望前台报表展示时可以雷同Excel表格筛选那样,在表头举行多选筛选过滤显示数据。其效果如下图所示:

针对以上需求,本文提出一种可行的方案,其大致步调如下:

  • 在原表需过滤字段后面增长一个单元格放置下拉框。
  • 将下拉框的字典设置为该字段的去重列表。
  • 下拉框编辑结束时将值传递给指定的参数控件,并提交查询。
  • 利用填报预览,可以直接在单元格中利用控件。
  • 在页面初始化时通过JS调整前台样式,隐藏参数栏等。
注1:不支持移动端填报。
注2:本文涉及到的技术及流程均仅在FineReport 11.0 版本举行实际验证,假如您在利用其他版本过程中出现题目可以联系本作者。
二、详细操纵

第一步

示例所需数据集,如下:
  1. -- ds1 数据集
  2. select 订单ID,substr(订购日期,0,11) as 订购日期,客户ID,雇员ID,运货商,运货费,货主名称,货主地址
  3. from S订单
  4. where 1=1
  5. ${if(len(订单ID)==0,"","and 订单ID in ('"+订单ID+"')")}
  6. ${if(len(订购日期)==0,"","and substr(订购日期,0,11) in ('"+订购日期+"')")}
  7. limit 50
  8. -- 参数 订单ID数据集
  9. select distinct 订单ID from S订单
  10. -- 参数订购日期数据集
  11. select distinct substr(订购日期,0,11) as 订购日期 from S订单
复制代码
其参数控件也皆在参数栏方式好,设置好。

第二步

打开模板,在模板需要调整的字段右侧增长单元格用来存放下拉框控件,同时将下方数据表字段和右侧的空白单元格举行合并。

同时,需要调整单元格的对齐及边框,使其尽大概像是在同一个单元格中。
值得留意的是,下拉框的单元格要稍小一些,否则容易造成图标的错位,同时,下拉框所在的单元格要设置成不自动调整。

第三步

给控件设置其数据字典。并调整控件返回的数据范例为字符串,且分隔符同时调整为','。

第四步

给控件增长一个编辑结束事件,并写入如下代码:

JavaScript 代码如下:
  1. // 将控件的值传递给参数控件。
  2. _g().getParameterContainer().getWidgetByName("订单ID").setValue(this.getValue());
  3. // 提交参数查询
  4. _g().parameterCommit();
复制代码
第五步

点击左上角 模板->模板web属性->填报页面设置->事件设置 中增长加载结束事件,并写入如下JavaScript脚本。同时,需要将直接显示控件选项勾选,将利用工具栏取消勾选。

JavaScript 代码如下:
[code]// 去除控件的边框$(".fr-trigger-btn-up").css("border", "none");// 去除input边框并将其宽度设置为0举行隐藏$(".fr-trigger-text.fr-border-box").css({ "border": "none", "width": "0px" });// 判断表格地区的高度加上参数栏高度是否大于浏览器高度if ($(".content-container").height() + $(".parameter-container").height()

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

惊落一身雪

金牌会员
这个人很懒什么都没写!

标签云

快速回复 返回顶部 返回列表