【问题标题】:Telerik HTML5 Report Viewer - Error loading the report viewer's templatesTelerik HTML5 报表查看器 - 加载报表查看器模板时出错
【发布时间】:2016-05-11 22:11:09
【问题描述】:

我在尝试使用 Telerik REST 服务及其 HTML5 报告查看器时遇到问题。

这是我的场景:

我有一个托管 REST 服务 API 的 C# 控制台应用程序。我已经按照 Telerik 的文章设置了这个项目:How To: Self Host Telerik Reporting REST Web API。这似乎没有问题。我可以转到http://localhost:8080/api/reports/formats 并得到预期的结果,这表明 REST 服务器可用并且正在处理请求。

然后我设置了一个单独的项目来运行报表查看器。这是一个 C# Windows 窗体应用程序,它有一个指向我的报表查看器 HTML 文件的 URL 的 WebBrowser 元素。当您在 Visual Studio 中创建新的 Telerik HTML 5 报表查看器时,报表查看器 HTML 文件是默认生成的文件 - 它为您构建所有必要的部分。代码如下:

<!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。

谢谢!

【问题讨论】:

  • 不是serviceUrltemplateUrl 路径是否正确?据我记得,模板不应该包含版本号。
  • 据我所知,templateUrl 路径是正确的。您在那里看到的版本号只是文件名的一部分。我尝试将文件重命名为没有版本号,但无济于事。

标签: c# asp.net html reporting-services telerik


【解决方案1】:

我发现了我的问题。原来这是一个跨域问题。我最终获取了所需的模板和脚本等,并将它们托管在服务器上的一个简单的 IIS 页面上,并使用绝对 URL 引用它们。这让我解决了我遇到的问题。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 2010-12-20
    • 1970-01-01
    • 1970-01-01
    • 2014-06-24
    • 2014-03-28
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多