1. 概述
1.1 预期效果
填报时,在对报表进行审核、提交成功后,我们希望对工具栏的一些按钮做属性的改变,比如:设置不可用、不可见,从而防止误操作。如下图所示,提交成功后,打印和输出功能不可用。
1.2 实现思路
在「模板 Web 属性>填报页面设置」,添加「填报成功」事件,用 JS 根据按钮的序号设置按钮是否可用或可见。
2. 示例
2.1 准备模板
准备一个填报模板。
2.2 添加事件
打开模板,选择「模板>模板 Web 属性>填报页面设置」,选择「为该模板单独设置」,添加一个「填报成功」事件,如下图所示:
JavaScript 代码如下:
注:设置属性时,不可将当前触发事件的按钮设置不可用属性(既“提交”按钮不可做设置)
contentPane.toolbar.options.items[3].setEnable(false);
//从左往右,下标从0开始,第四个按钮(打印)不可用
contentPane.toolbar.options.items[4].setEnable(false);
//从左往右,下标从0开始,第五个按钮(输出)不可用
要实现初始化时某些按钮不可用,可以添加「加载结束」事件,事件中代码需要增加一个延迟函数。如下图所示:
setTimeout(function(){contentPane.toolbar.options.items[3].setEnable(false);
//从左往右,下标从0开始,第四个按钮(打印)不可用
contentPane.toolbar.options.items[4].setEnable(false);
//从左往右,下标从0开始,第五个按钮(输出)不可用
},1000);
代码解释:
contentPane.toolbar.options.items:返回的是工具栏所有按钮的数组集合,通过下标(从 0 开始)进行引用。
获取报表工具栏按钮的 JS 语句还有其他格式,见文档:工具栏JS实例
2.3 效果预览
保存模板,使用填报预览,预览效果如下图所示:
注:不支持移动端。
3. 模板下载
已完成的模板,可参见:%FR_HOME%\webapps\webroot\WEB-INF\reportlets\doc\JS\工具栏JS实例\04-JS控制工具栏按钮的属性.cpt
点击下载模板:04-JS控制工具栏按钮的属性.cpt