技巧汇总:
报表生成阶段的事件:
1、 报表级事件:
initialize 在报表开始执行生成阶段前执行。包含定义全局变量、函数、和对象。
beforeFactory :在开始生成阶段之前执行。可以访问报表中的元素。如数据集、标签等等。
afterFactory:在开始生成阶段阶段之前执行
2、 数据源事件:
beforeOpen:在BIRT打开数据源连接之前执行,一般进行连接数据源的配置信息的编写,包括:驱动、数据库的URL、用户名、密码等等。
AfterOpen :在BIRT打开数据源连接之后执行
BeforeCLose::在BIRT关闭数据源连接之前执行
afierClose: 在BIRT关闭数据源连接之后执行
3、 数据集事件:
beforeOpen:在BIRT打开数据集之前执行,一般编写要执行的SQL语句。
AfterOpen :在BIRT打开数据集之后执行
Onfetch:获取每一行的数据以后,并应用过滤器计算列之前执行onFetch事件处理程序。
BeforeCLose::在BIRT关闭数据源连接之前执行
afierClose: 在BIRT关闭数据源连接之后执行
4、报表元素事件:
onPrepare:在报表生成阶段调用,并且针对报表设计中的每一个元素,在此事件中就可以修改元素的设计。
onCreate:在此事件中可以修改和访问元素的实例。
报表显示阶段事件:
1、报表级事件:
initialize : 在报表开始执行显示阶段前执行。在初始化事件中可以定义全局变量、函数、和对象。
beforeRender:在开始显示阶段前执行。
afterRender:在开始显示阶段后执行。
2、报表元素事件:
onRender:可以改变元素实例。
-----------------------------------------------------------------
序号
整个表格
onCreate事件
var index=0;
标签 onCreate事件
index++;
this.text=index;
分页
选择数据行,脚本
onPrepare事件
var count=0;
onCreate事件
count++;
if(count % 20 == 0){
style.pageBreakAfter = "always";
}
if(count%2==0)
{this.getStyle().backgroundColor = "#EFEFEF";
}
else
{this.getStyle().backgroundColor="#d4d0c8";}
突出显示(隔行换色)
row.__rownum %2 !=0 RGB(246,246,247)
标题日期间隔
var bdate=params["beginDate"].value.split("-");
var edate=params["endDate"].value.split("-");
bdate[0]+"年"+bdate[1]+"月"+bdate[2]+"日 至 "+ edate[0]+"年"+edate[1]+"月"+edate[2]+"日";
标题
decodeURI(params["specialty"].value).concat(" ").concat("合同列表");
相关 使用技巧网文