反馈已提交

网络繁忙

FVS实现控件联动并查询

  • 文档创建者:TW
  • 历史版本:11
  • 最近更新:TW 于 2024-10-28
  • 1. 概述

    适用场景:安装了「FineVis数据可视化」插件的用户,可参考本文了解 FVS 模板的相关功能。

    1.1 版本

    报表服务器版本
    插件版本
    11.0.6V1.5.0

    1.2 应用场景

    在 FVS可视化看板中,希望实现有多个控件时,后一个控件的选项能根据前一个控件选择的值变化,并且在选择相应的选项后,其他组件内容能随之变化展示相应的数据。

    如下图所示,城市选项需跟随地区所选值而变动,客户选项需跟随地区、城市所选值相应变动,表格内容能跟随选择的地区、城市、客户自动查询出相应数据。

    留.gif

    1.3 实现思路

    通过在数据集中定义数据集参数,再在画布中添加控件,控件绑定带有参数的数据字典时,即可实现后面控件根据前面控件数据进行过滤。

    通过给单元格添加过滤条件实现表格数据自动查询。

    2. 示例

    2.1 新建模板

    1)在 FineReport 设计器左上角点击「文件>新建可视化看板」。

    2)在「创建空白看板」Tab 中,可自定义模板名称和尺寸,选择 模板样式 为「内置样式>深色主题一」。

    3)点击「创建看板」。

    1.png

    2.2 数据准备

    新建三个数据库查询,SQL 查询语句分别为:

    订单:select 客户.地区,客户.城市,客户.客户ID,客户.公司名称,订单.订单ID,订单.订购日期,订单.发货日期,订单.到货日期,订单.运货商,货主名称,订单明细.产品ID,(订单明细.单价*订单明细.数量) AS 金额 from 客户,S订单 订单,S订单明细 订单明细 where 订单.订单ID=订单明细.订单ID and 客户.客户ID=订单.客户ID

    城市:select 城市 from 客户 where 地区='${area}'

    客户:select 公司名称 from 客户 where 城市='${city}' and 地区='${area}'

    「订单」数据集主要将不同的数据表进行了关联;「城市」数据集定义了地区参数 $area ,表示根据参数获取对应的「城市」;「客户」数据集定义了城市参数 $city 和 地区参数 $area,表示根据参数获取对应的「公司名称」。

    以订单为例,如下图所示:

    7.png

    2.3 设计可视化看板

    1)向画布中拖入四个「标题」组件、三个「下拉框」控件和一个「表格」组件,并调整组件位置。如下图所示:

    8.png

    9.png

    2)分别设置「标题」组件「标题内容」为 地区:、城市:、客户:,下图为地区示例。

    10.png

    「下拉框」组件「绑定参数」分别为 area 、city 、customer,将下拉框控件与各个参数绑定,下图为area参数示例。

    注:必须保证下拉框绑定参数与参数名称一致。

    11.png

    3)设置三个「下拉框」控件的选项值来源,具体设置如下表所示:

      绑定参数类型设置数据来源  实际值     显示值 
    area数据库表 FRDemo 数据库/订单表  货主地区  货主地区
     city数据查询城市数据集
      城市  城市
    customer数据查询客户数据集公司名称公司名称

    以 area 控件为例,步骤如下图所示:

    12.png

    2.4 设计表格

    2.4.1 设计表格样式

    1)选中「标题」,在「标题内容」中设置标题为「运货商月订单信息」如下图所示:

    13.png

    2)选中表格组件,点击右侧的「编辑组件」,进入表格编辑界面,如下图所示:

    14.png

    3)将「订单」数据集中的 订单ID、公司名称、订购日期、货主名称、发货日期、到货日期、运货商 依次拖入 A2~G2 单元格,再输入对应表头信息。如下图所示:

    图1.png

    4)因为 G2 单元格的「运货商」字段在「订单」数据集中实际上是「运货商ID」的字段值,所以这里需要设置其形态为数据字典,使其显示「运货商ID」对应的「公司名称」。

    选中 G2 单元格,点击「单元格属性>形态」,设置为「数据字典」,将其显示值设为「运货商」表中的「公司名称」字段。如下图所示:

    15.png

    2.4.2 设置过滤

    由于表格中的数据与下拉框选项值来源绑定的数据并不是来源于同一个数据集,它们之间不存在过滤关系,所以需要手动为单元格添加过滤条件。

    双击「订单 ID」所在的 A2 单元格,弹出数据列设置界面,选择「过滤」界面,添加三个过滤条件,条件之间用 AND 连接:

    条件一:地区 列等于 F(x) if(len($area)== 0,nofilter,$area)

    条件二:城市 列等于 F(x) if(len($city)== 0,nofilter,$city)

    条件三:公司名称 列等于 F(x) if(len($customer)==0,nofilter,$customer)

    注1:参数 $customer 可以直接引用「下拉框控件」customer 的值。

    注2:公式中 nofilter 是不过滤的意思,即参数为空时不过滤显示全部数据,参数不为空时,显示出相应数据。

    如下图所示:

    图1.png

    2.5 效果预览

    2.5.1 PC 端

    保存报表,点击「预览」,效果如 1.2 节应用场景所示。

    2.5.2 移动端

    移动端请自行组合并开启 移动端布局 ,预览方式请参考 FVS移动端预览 。效果如下图所示:

    题词.gif

    3. 模板下载

    点击下载模板:FVS实现控件联动并查询.fvs

    附件列表


    主题: FineVis数据可视化
    • 有帮助
    • 没帮助
    • 只是浏览
    中文(简体)

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

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

    不再提示

    10s后关闭



    AI

    联系我们
    在线支持
    获取专业技术支持,快速帮助您解决问题
    工作日9:00-12:00,13:30-17:30在线
    页面反馈
    针对当前网页的建议、问题反馈
    售前咨询
    采购需求/获取报价/预约演示
    或拨打: 400-811-8890 转1
    qr
    热线电话
    咨询/故障救援热线:400-811-8890转2
    总裁办24H投诉:17312781526
    提交页面反馈
    仅适用于当前网页的意见收集,帆软产品问题请在 问答板块提问前往服务平台 获取技术支持