反饋已提交

網絡繁忙

當前為10.0版本文檔,更多實例內容將在最新幫助文檔中展現,點選跳轉至 最新版幫助文檔

JS获取决策报表内图表块刷新数据

1. 概述

1.1 问题描述

决策报表中,当报表块和图表块之间有联动且图表块的数据来源于报表块单元格时,当报表块数据发生变化后,图表块数据不会随着变化。如下图所示:

chart0 联动 report0 报表块,chart1 数据来自 report0 报表块。report0 报表块数据发生变化后,chart1 不会自动刷新。

2020-12-24_19-19-54.gif

如果我们想要实现报表块数据发生变化后,联动的图表块也会自动刷新,要怎么做呢?

如下图所示,report0 报表块数据发生变化后,chart1 会随着自动刷新。

2020-12-24_19-25-15.gif

1.2 实现思路

添加 JS,使用 c.dataRefresh() 图表刷新接口,实现报表块数据改变后刷新图表。

2. 示例

2.1 准备模板

打开内置模板:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\Advanced\mobile-client\ ChartDelayRefresh_1.frm

点击可下载模板:ChartDelayRefresh_1.frm

2.2 修改模板

1)将模板中饼图和柱形图删掉,替换成饼图(新特性)和柱形图(新特性)。饼图数据设置如下图所示:

image.png

2)柱形图数据来源为报表块 report0 的单元格。如下图所示:

image.png

3)为饼图 chart0 添加交互属性,使点击饼图不同分区时,传递地区参数 area 给报表块 report0,从而导致报表块数据发生变化。如下图所示:

image.png

至此,模板已实现了chart0 联动 report0 报表块,chart1 数据来自 report0 报表块,但report0 报表块数据发生变化后,chart1 不会自动刷新。

2.3 增加刷新JS

要实现 report0 报表块数据发生变化后,chart1 会随着自动刷新,需给饼图 chart0 增加刷新 JS。如下图所示:

image.png

JavaScript 代码如下:

setTimeout(function() {
    var c = FR.Chart.WebUtils.getChart("chart1");//获取图表块chart1
    c.dataRefresh();//刷新图表块chart1
}, 500);//延迟0.5秒后刷新

2.4 效果预览

保存模板,点击「PC端预览」,PC端效果如下图所示:

222

移动端效果如下图所示:

222


3. 模板下载

已完成的模板,可参见:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\JS\表单JS实例\21-JS获取决策报表内图表块刷新数据.frm

点击下载模板:21-JS获取决策报表内图表块刷新数据.frm

附件列表


主題: 原简体文档
已經是第一篇
已經是最後一篇
  • 有幫助
  • 沒幫助
  • 只是瀏覽
  • 圖片不清晰
  • 用語看不懂
  • 功能說明看不懂
  • 操作說明太簡單
  • 內容有錯誤

文 檔回 饋

滑鼠選中內容,快速回饋問題

滑鼠選中存在疑惑的內容,即可快速回饋問題,我們將會跟進處理。

不再提示

10s後關閉