页面树结构
转至元数据结尾
转至元数据起始

该宏示例在 V10.5上 验证通过

提示:本文档的示例代码仅适用于本文档中的示例报表/场景。若实际报表/场景与示例代码无法完全适配(如使用功能不一致,或多个宏代码冲突等),需根据实际需求开发代码。

示例说明

当在大屏幕上显示报表时,我们有时候需要对报表分页并且自动循环播放每一页的内容。

轮播的效果如下:

版本及客户端说明

1.smartbi版本:V9

2.客户端:PC

3.浏览器:IE11、谷歌浏览器(Chrome)、火狐浏览器(Firefox)

设置方法

1、首先在电子表格设计器(Microsoft Office Excel)中,创建电子表格报表。

2、在浏览器的“分析展现”节点下,选中电子表格,右键选择 编辑宏 进入报表宏界面。

3、在报表宏界面新建客户端模块。在弹出的新建模块对话框中,选择对象为spreadSheetReport、事件为onRender、并把下面宏代码复制到代码编辑区域。

宏类型

类型

对象

事件

ClientSide

spreadsheetReport

onRender


宏代码

function main(spreadsheetReport, isAjaxRefreshCallback) {
    setTimeout(function() {
        if (!spreadsheetReport.elemPageNext.disabled) {
            spreadsheetReport.onPageNext();
        } else {
            spreadsheetReport.pageIndex = 0;
            spreadsheetReport.setPageCtrlStatus();
            spreadsheetReport.doPage();
        }
    }, 5000)
}

如果工具栏需要隐藏的情况下进行轮播,则参考以下宏:


function main(spreadsheetReport, isAjaxRefreshCallback) {
    spreadsheetReport.elem_trPagePanel.style.display = "none";
    var pageCount =  spreadsheetReport.sheetPageCounts[spreadsheetReport.currentSheetIndex];//获取总页数
    setTimeout(function() {
        if (spreadsheetReport.pageIndex < pageCount - 1) {

            spreadsheetReport.onPageNext();

        } else {
            spreadsheetReport.pageIndex = 0;
            spreadsheetReport.setPageCtrlStatus();
            spreadsheetReport.doPage();
        }

    }, 5000)

}


关键对象总结

  • 通过spreadsheetReport.onPageNext();方法,下一页。


资源下载

资源:migrate.xml