【问题标题】:Render ASP.NET MVC PartialView Using AngularJS使用 AngularJS 渲染 ASP.NET MVC PartialView
【发布时间】:2016-05-10 01:17:34
【问题描述】:

我正在尝试使用 ASP.NET MVC 5 将 Report Viewer for MVC 集成到我的 Angular 应用程序中。

报告:

查看/报告/Index.cshtml

@model JET.Shop.Common.Models.ReportRequestModel
@using ReportViewerForMvc;
<div>
    <div class="row">
        <div class="col-md-5">
            @using (Html.BeginForm("Index", "Report", FormMethod.Post))
            {
                <div class="form-group">
                    <label>Start Date</label>
                    @Html.TextBoxFor(model => model.StartDate, string.Format("{0:d}", DateTime.Now), new { @id = "startDate", @class = "datefield", type = "date" })
                </div>
                <div class="form-group">
                    <label>End Date</label>
                    @Html.TextBoxFor(model => model.EndDate, string.Format("{0:d}", DateTime.Now), new { @id = "endDate", @class = "datefield", type = "date" })
                </div>
            }
        </div>
        <div class="col-md-7">
            <div class="form-group">
                <input type="submit" value="Generate" />
            </div>
        </div>
    </div>
    <div class="row">
        @Html.ReportViewer(ViewBag.ReportViewer as Microsoft.Reporting.WebForms.ReportViewer)
    </div>
</div>

报表控制器

public class ReportController : Controller
{
    // GET: Report
    public ActionResult Index(ReportType reportType = ReportType.SalesOrderList)
    {
        ReportRequestModel model = new ReportRequestModel();

        model.Type = reportType;
        model.StartDate = DateTime.Now;
        model.EndDate = DateTime.Now;

        return PartialView(model);
    }

    [HttpPost]
    public ActionResult Index(ReportRequestModel request)
    {
        List<ReportParameter> reportParams = new List<ReportParameter>();
        ReportViewer reportViewer = new ReportViewer();
        reportViewer.ProcessingMode = ProcessingMode.Local;

        SalesOrdersListDataSet salesOrderDataSet = new SalesOrdersListDataSet();
        salesOrderDataSet.SalesOrder.AddSalesOrderRow(Guid.NewGuid(), DateTime.Now, DateTime.Now, DateTime.Now.AddDays(1), 500, 60, 440, "Complete");
        salesOrderDataSet.SalesOrder.AddSalesOrderRow(Guid.NewGuid(), DateTime.Now, DateTime.Now, DateTime.Now.AddDays(1), 100, 12, 88, "Complete");

        ReportDataSource reportDataSource1 = new ReportDataSource();
        reportDataSource1.Name = "Report"; //Name of the report dataset in our .RDLC file
        reportDataSource1.Value = salesOrderDataSet.SalesOrder;

        reportViewer.LocalReport.DataSources.Add(reportDataSource1);
        reportViewer.LocalReport.ReportEmbeddedResource = "JET.Shop.WebApp.Reports.SalesOrderListReport.rdlc";
        reportViewer.LocalReport.SetParameters(reportParams);

        ViewBag.ReportViewer = reportViewer;

        return PartialView(request);
    }
}

路由配置

routes.MapRoute(
               name: "ReportController",
               url: "Report/Index/{reportType}",
               defaults: new { controller = "Report", action = "Index", reportType = UrlParameter.Optional }
            );

$RouteProvider

.when("/Report", {
                    templateUrl: "/Report/Index",
                    controller: "ReportController",
                    loginRequired: true,
                    requiredRoles: ["Admin"]
                })

我基本上想尝试呈现此报表查看器,但我遇到了 HTTP 500 - 控制台上的内部服务器错误。

我做了一些随机试验和错误,发现如果我让我的 Report/Index.cshtml 只包含纯 HTML(没有剃刀),它会呈现。但是当我在视图中包含我的@model 语句时,我得到 HTTP 500。有人可以帮我解决这个问题吗?我的控制器(GET 索引)的断点工作正常。

仅供参考,我通过浏览器上的 URL 直接访问它来导航到报告页面,仅用于快速测试。

关于我应该如何处理这个问题的任何建议?我的主要目标是显示一个 ReportViewer,因为一旦它在视图上呈现,我就可以从那里工作。

Report/Index.cshtml 带有可以工作的纯 HTML..

@*@model JET.Shop.Common.Models.ReportRequestModel
@using ReportViewerForMvc;*@

<div>
    <div class="row">
        <div class="col-md-5">
            @*@using (Html.BeginForm("Index", "Report", FormMethod.Post))
            {
                <div class="form-group">
                    <label>Start Date</label>
                    @Html.TextBoxFor(model => model.StartDate, string.Format("{0:d}", DateTime.Now), new { @id = "startDate", @class = "datefield", type = "date" })
                </div>
                <div class="form-group">
                    <label>End Date</label>
                    @Html.TextBoxFor(model => model.EndDate, string.Format("{0:d}", DateTime.Now), new { @id = "endDate", @class = "datefield", type = "date" })
                </div>
            }*@
            THIS WORKS FINE!
        </div>
        <div class="col-md-7">
            <div class="form-group">
                <input type="submit" value="Generate" />
            </div>
        </div>
    </div>
    <div class="row">
        @*@Html.ReportViewer(ViewBag.ReportViewer as Microsoft.Reporting.WebForms.ReportViewer)*@
    </div>
</div>

【问题讨论】:

    标签: c# asp.net angularjs asp.net-mvc crystal-reports


    【解决方案1】:

    只是为了结束这个问题,

    我最终根本没有使用报表查看器。我刚刚创建了一个 MVC 控制器,它可以从水晶报表生成 Excel/PDF。

    【讨论】:

      猜你喜欢
      • 2012-07-23
      • 1970-01-01
      • 2014-09-10
      • 2013-12-06
      • 2017-07-02
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2011-06-18
      相关资源
      最近更新 更多