我在尝试使用Telerik REST服务及其HTML5报告查看器时遇到问题。
这是我的方案:
我有一个托管 REST 服务 API 的 C# 控制台应用程序。我已经根据Telerik的文章设置了这个项目:如何:自托管Telerik报告REST Web API。这似乎没有问题。我能够去 http://localhost:8080/api/reports/formats,我得到了预期的结果,这对我来说表明 REST 服务器可用并且正在处理请求。
然后,我设置了一个单独的项目来运行报表查看器。这是一个 C# Windows 窗体应用程序,它有一个指向我的报表查看器 HTML 文件的 URL 的 WebBrowser 元素。报表查看器 HTML 文件是在 Visual Studio 中创建新的 Telerik HTML 5 报表查看器时默认生成的文件 - 它会为您生成所有必需的部分。这是代码:
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>Telerik HTML5 Report Viewer</title>
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1" />
<meta http-equiv="X-UA-Compatible" content="IE=edge" />
<link href="http://netdna.bootstrapcdn.com/font-awesome/3.2.1/css/font-awesome.css" rel="stylesheet" />
<script src="http://code.jquery.com/jquery-1.9.1.min.js"></script>
<link href="http://cdn.kendostatic.com/2013.2.918/styles/kendo.common.min.css" rel="stylesheet" />
<link href="http://cdn.kendostatic.com/2013.2.918/styles/kendo.blueopal.min.css" rel="stylesheet" />
<!--kendo.all.min.js can be used as well instead of kendo.web.min.js and kendo.mobile.min.js-->
<script src="http://cdn.kendostatic.com/2013.2.918/js/kendo.web.min.js"></script>
<!--kendo.mobile.min.js - optional, if gestures/touch support is required-->
<script src="http://cdn.kendostatic.com/2013.2.918/js/kendo.mobile.min.js"></script>
<link href="ReportViewer/styles/telerikReportViewer-9.0.15.324.css" rel="stylesheet" />
<script src="ReportViewer/js/telerikReportViewer-9.0.15.324.min.js"></script>
<style>
#reportViewer1 {
position: absolute;
left: 5px;
right: 5px;
top: 5px;
bottom: 5px;
overflow: hidden;
font-family: Verdana, Arial;
}
</style>
</head>
<body>
<div id="reportViewer1">
</div>
<script type="text/javascript">
$(document).ready(function () {
$("#reportViewer1")
.telerik_ReportViewer({
serviceUrl: "http://localhost:8080/api/reports/",
templateUrl: "ReportViewer/templates/telerikReportViewerTemplate-9.0.15.324.html",
//ReportSource - report description
reportSource: {
report: "Reports/SampleReport.trdx",
parameters: {
Date: new Date(),
}
},
viewMode: telerikReportViewer.ViewModes.INTERACTIVE,
scaleMode: telerikReportViewer.ScaleModes.SPECIFIC,
scale: 1.0,
ready: function () {
//this.refreshReport();
},
});
});
</script>
</body>
</html>
运行此应用程序时,Web 浏览器会加载页面,但随后显示" 加载报表查看器的模板时出错"。我尝试将模板放在服务器端,但我似乎无法弄清楚我做错了什么。
如果有人对我可以尝试解决此错误的方法有任何建议,我将不胜感激!我正在使用Telerik 2015 Q1。
谢谢!
我找到了我的问题。事实证明,这是一个跨源问题。我最终采用了所需的模板和脚本等,并将它们托管在服务器上的简单 IIS 页面上,并使用绝对 URL 引用它们。这让我解决了我遇到的问题。