反馈已提交
网络繁忙
点击「菜单服务器>服务器配置」,会弹出服务器设置的界面,在服务器配置处设置的「分页预览」,「填报预览」,「数据分析」,「引用 Css」,「引用 JavaScript」,「出错模板定义」,「打印设置」,「PC 端自适应」的属性是适用于整个服务器下的模板的,如下图所示:
分页预览设置页面,对整个服务器下所有模板的分页预览有效。例如点击「菜单服务器>服务器配置>分页预览」,将报表显示位置勾选居中显示,点击「确定」。如下图所示:
再点击「模板>模板 Web 属性」,选择分页预览,选择采用服务器设置,可见报表显示位置已经变为居中显示,如下图所示:
填报页面设置,对整个服务器下所有模板的分页预览有效。与第二节分页预览效果相似,不再重复赘述。
数据分析设置,对整个服务器下所有模板的数据分析预览生效。与第二节分页预览效果相似,不再重复赘述。
服务器配置相对模板 Web 属性,增加了出错模板定义功能。
注:出错模板定义仅支持 PC 端。
报表自带的报错页面色调如下图,但是客户项目可能有自己的色调和统一的出错页面,与我们提供的不一致,因此需要使用自定义出错页面。
在「服务器>服务器配置>出错模板定义」直接调用自定义的出错页面如:/error.html,页面中可以通过模板出错参数 message、charset、exception 获取到报错信息。
在使用自定义出错页面的时候可以调用报表系统错误页面的参数,下面简单的列出参数以及说明。
参数
说明
如上的参数可以通过 ${参数名} 的形式调用。如在定义的 error.html 页面中调用参数 message 将提示错误信息显示在表格中,如下:
<html> <body> <table> <tr> <td> ${message} </td> </tr> </table> </body> </html>
定义好的出错页面在「服务器>服务器配置>出错模板定义」的模板路径中调用,可以通过相对路径进行调用:
相对路径:自定义的出错页面 error.html 放在当前 Web 应用下,如 webroot 目录下,通过相对路径进行调用,模板路径为:/error.html。
注:html 类型文件不支持使用绝对路径进行调用。
在「服务器>服务器配置>PC 端自适应属性」中,用户可对服务器配置的「新决策报表」、「决策报表」、「普通报表」的自适应属性进行修改,对整个服务器下模板生效,如下图所示:
例如选择「普通报表」,将「字体」和「表格」分别勾选「自适应」和「双向自适应」,如下图所示:
再新建普通报表,点击「模板>PC 端自适应属性」,选择「采用服务器设置」,可见「字体」和「表格」已变为「自适应」和「双向自适应」,如下图所示:
「服务器配置>引用 CSS」对整个服务器下的模板生效。与「模板 Web 属性>引用 CSS」仅作用范围不同,详情请参见:引用 CSS 。
「服务器配置>引用 JavaScript」对整个服务器下的模板生效。与「模板 Web 属性>引用 JavaScript」仅作用范围不同,详情请参见:引用 JavaScript 。
若不为报表的预览方式进行单独设置时,统一采用服务器配置。若为报表的预览方式进行单独设置时,会以单独设置的属性进行显示。
在出错文字为中文的情况下,使用了 ${message} ,会出现乱码。
比如找不到模板文件,错误代码 : 1304 ;没有找到模板文件 : GettingStarted2.cpt ;
使用上述自定义出错信息的话,出错信息如下图所示:
后面的英文部分显示正常,中文部分却是乱码,显示不是我们需要的,那么如何解决呢?
出错的信息是通过 FR 进行转码过后的,中文会被显示成上述样式,为了还原,我们需要在error.html文件中使用 FR.cjkDecode() 来进行还原出错的信息,使用这个方法必须加载 finereport.js 文件,路径为/webroot/decision/view/report?op=emb&resource=finereport.js,需要在 HTML 中引用,如下图:
由于页面使用的 ${message} 是在页面加载后完成的,所有js转码部分必须写在 body 内部,在 ${message} 之后,为了获取此信息,我们加一组 span 标签,class 设置为 message,利用 jQuery 中的 $('.message').text() 就可以获取和设置信息内容了,如下图:
注:在 JS 部分,不能直接使用 ${message} 来获取出错信息内容,所以必须使用jquery或其他方法来获取 span 中的信息内容。
完整的源代码如下:
<html> <head> <script src="/webroot/decision/view/report?op=emb&resource=finereport.js"></script> </head> <body> <table> <tr> <td> <span class='message'>${message}</span> </td> <td></td> </tr> </table> <script> $('.message').text(FR.cjkDecode($('.message').text())); //因为错误信息是转码之后的,必须解码 </script> </body> </html>
保存后再新刷新页面,即可看到新的出错信息了,如下图:
可以看到,已经正确地还原了出错信息了。
售前咨询电话
400-811-8890转1
在线技术支持
请前往「服务平台」,选择「在线支持」
热线电话:400-811-8890转2
总裁办24H投诉
热线电话:173-1278-1526
文 档反 馈
鼠标选中内容,快速反馈问题
鼠标选中存在疑惑的内容,即可快速反馈问题,我们将会跟进处理。
不再提示
10s后关闭