使用Javascript打印输出
教学视频
概述
通过引用报表中的一个Javascript文件,调用该文件中的相关方法,实现报表的预览、打印和导出功能。
引用Javascript文件
Javascript文件URL格式如下:
http[s]://host[:port]/[context-path]/baskserver/res/baskreport/js/view/BaskReport.bundle.js
在我们的HTML文件中通过上面的URL引入BaskReport中提供的名为BaskReport.bundle.js的Javascript文件后,接下来就可以在自己的Javascript代码中通过Javascript调用实现特定报表的预览、打印和导出功能。
使用Javascript调用报表
引入BaskReport.bundle.js文件后,当前的HTML文件中就可以直接使用BaskReport这个Javascript对象,这个对象中提供的方法如下表所示:
方法名 | 说明 | 语法 |
---|---|---|
doPrint | 直接打印报表文件 | BaskReport.doPrint({id:reportFileId,[parameters:{name:value},] baseUrl:reportServerUrl}); |
doSilentPrint | 2.1.1版本开始支持,将报表发送给BaskReport打印服务器,实现无预览打印或者叫静默打印, BaskReport无预览静默打印详情点击此处了解 |
BaskReport.doSilentPrint({id:reportFileId,[parameters:{name:value},] baseUrl:reportServerUrl}); |
doMultiPrint | 直接打印多个报表文件, 将多个报表文件合并在一个文件中打印输出 |
BaskReport.doMultiPrint({files:[ { id:reportFileId[,parameters:{name:value}] }, { id:reportFileId[,parameters:{name:value}] } ], baseUrl:reportServerUrl}); |
doPreview | 新开窗口以HTML形式预览报表文件 | BaskReport.doPreview({id:reportFileId, [parameters:{name:value},] baseUrl:reportServerUrl}); |
doExportWord | 直接将报表文件以word形式导出 | BaskReport.doExportWord({ id:reportFileId, [parameters:{name:value},] baseUrl:reportServerUrl}); |
doExportExcel | 直接将报表文件以excel形式导出 | BaskReport.doExportExcel({ id:reportFileId, [parameters:{name:value},] baseUrl:reportServerUrl}); |
doExportMultiExcel | 导出多个报表文件,将多个报表文件放在一个Excel文件不同的Sheet页中导出。 | BaskReport.doExportMultiExcel({ files:[ { id:reportFileId[,parameters:{name:value}] }, { id:reportFileId[,parameters:{name:value}] } ] baseUrl:reportServerUrl}); |
doExportPdf | 直接将报表文件以pdf形式导出 | BaskReport.doExportPdf({ id:reportFileId, [parameters:{name:value},] baseUrl:reportServerUrl}); |
doExportCsv | 直接将报表文件以csv形式导出 | BaskReport.doExportCsv({ id:reportFileId, [parameters:{name:value},] baseUrl:reportServerUrl}); |
doExportMultiPdf | 直接导出多个报表文件, 将多个报表文件合并在一个pdf文件中导出 |
BaskReport.doExportMultiPdf({ files:[ { id:reportFileId[,parameters:{name:value}] }, { id:reportFileId[,parameters:{name:value}] } ] baseUrl:reportServerUrl}); |
doSave | 调用目标iframe窗口中存在的报表填报页面里的保存功能,实现数据填报提交。 需要在当前页面中通过iframe嵌入填报页面,且需要为这个iframe指定ID值; 同时在调用这个方法时,还可以添加一个名为callback的参数用于指定保存成功后要执行的回调函数, 该函数入参只有一个,里面包含当前提交的数据(数据需要调用decodeURIComponent方法解码),文件ID等信息。 |
BaskReport.doSave({iframe:"iframeId"[,callback:function]}) |
上面的语法中,reportFileId表示具体的已发布的报表文件ID,parameters属于可选参数,baseUrl表示报表服务器的URL,比如:http://192.168.18.106:8080/baskserver-test 。
上面的方法中,需要注意的是访问的目标报表文件必须是已发布的,否则可能会出现访问不了的情况。 同时在访问报表文件时,还要保证访问的URL处理登录状态。如果当前报表引擎与应用集成在一起,那么登录不是问题,如果报表引擎与应用分别位于不同的系统当中,那么需要解决登录问题,具体可参考BaskServer平台中单点登录相关介绍。
参数说明
id
该参数用于指定报表文件的ID,id参数和code参数二选一
code
我们也可以通过报表的CODE参数访问它,该参数用于指定报表文件的CODE,id参数和code参数二选一,如果我们使用code参数,那么还需要提供tenantId参数。
BaskReport.doPrint({
code:reportFileCode,
tenantId: tenantId,
[parameters:{name:value},]
baseUrl:reportServerUrl
});
tenantId
在访问报表文件时,如果我们指定code时,如果系统存在多个团队,则一般来说我们推荐指定tenantId参数,便于查找到对应的文件资源。
name
在执行导出报表文件操作时,可以添加一个name参数用于指定报表导出后的文件名称,如果不加name参数,默认则采用目标报表名称为导出后的文件名(导出多个文件则采用第一个文件的文件名)。
parameters
报表参数,对应为报表设计器中的参数列表,该参数集合用JSON结构的数据声明,例如:
BaskReport.doPrint({
code:reportFileCode,
tenantId: tenantId,
parameters:{deptId:"D11",sex:true},
baseUrl:reportServerUrl
});
baseUrl
报表服务的URL
举例
下面的HTML中包含五个按钮,通过引用BaskReport.bundle.js文件,使用BaskReport对象提供的对应方法,实现打印单张报表、打印多张报表、预览HTML报表、导出Word以及导出多张报表到一个PDF文件的功能,JSP源码如下:
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>测试</title>
<script type="text/javascript" src="http://192.168.18.106:8080/baskserver-test/baskserver/res/baskreport/js/view/BaskReport.bundle.js"></script>
</head>
<body>
<button onClick="print()">打印单张报表</button>
<button onClick="multiprint()">打印多张报表</button>
<button onClick="preview()">预览HTML报表</button>
<button onClick="exportWord()">导出Word</button>
<button onClick="multiexport()">导出多张报表到一个PDF文件</button>
<script>
var REPORT_BASE_URL = 'http://192.168.18.106:8080/baskserver-test';
function print(){
BaskReport.doPrint({
id:2001,
baseUrl:REPORT_BASE_URL
});
}
function multiprint(){
BaskReport.doMultiPrint({
baseUrl:REPORT_BASE_URL,
files:[
{
id:2001
},
{
id:1501
}
]
});
}
function multiexport(){
BaskReport.doExportMultiPdf({
baseUrl:REPORT_BASE_URL,
files:[
{
id:2001
},
{
id:1501
}
]
});
}
function preview(){
BaskReport.doPreview({
baseUrl:REPORT_BASE_URL,
id:1501
});
}
function exportWord(){
BaskReport.doExportWord({
baseUrl:REPORT_BASE_URL,
id:1501
});
}
</script>
</body>
</html>
上面的例子当中,通过REPORT_BASE_URL变量定义要操作的报表文件所在的应用地址,REPORT_BASE_URL的值为:http://192.168.18.106:8080/baskserver-test ,这里的baskserver-test为应用的contextpath,需要注意的是,如果我们的应用没有contextpath,那么REPORT_BASE_URL的值就应该为:http://192.168.18.106:8080。
预览效果如下图: