无法转换类型&System; System.Data.Entity.Infrastructure.DbQuery'输入' PagedList.IPagedList'

时间:2016-05-05 09:40:52

标签: c# asp.net-mvc entity-framework-6 pagedlist

我正在尝试使用ASP.NET MVC 5应用程序的分页。 我用X.PagedList  我已经在一个简单的对象中正确实现了它,但是在使用更复杂的对象实现它时遇到了问题。例如,当我在论坛中拥有像帖子和评论这样的关系时。

我的模型具有以下结构

public class PublicReport
{
    [Key]
    [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    public int PublicReportID { get; set; }

    public string Title { get; set; }       
    ...
    public virtual Institutions Institution { get; set; }
    ...
}   

public class Institutions
{
    [Key]
    [DatabaseGenerated(DatabaseGeneratedOption.Identity)]
    public int InstitutionID { get; set; }
    public string Name { get; set; }
    ...
}

在控制器中是以下代码

public ActionResult ListReports(int? page)
{
    var pageNumber = page ?? 1;     
    var listOfReports = db.PublicReport.OrderByDescending(d => d.CreatedDate).Where(c => c.CategoryId == 1).ToList();
    listOfReports.ToPagedList(pageNumber, 3);
    return View("ReportList", listOfReports);
}

在视图(PartialView)中,相关部分是

@model IEnumerable<RENJK.Models.PublicReport>

@using PagedList.Mvc;
@using PagedList;   

@foreach (var item in Model)
{
    <div class="consult-post-sec">
        <div class="row">
            <div class="col-sm-12">
                <p>@Html.DisplayFor(modelItem => item.Title)</p>
                <div class="consult-posts-by">
                    @Html.DisplayFor(modelItem => item.Institution.Name)
                </div>
            </div>
        </div>
    </div>
}

@Html.PagedListPager((IPagedList)Model, page => Url.Action("Index", new { page }), PagedListRenderOptions.OnlyShowFivePagesAtATime) 

我得到的错误是

  

无法转换类型&System; System.Collections.Generic.List`1 [RENJK.Models.PublicReport]&#39;输入&#39; PagedList.IPagedList&#39;。

问题似乎出现在代码行的视图中,我想显示ListPager,因为如果删除它,错误就不会显示。

在这种情况下我该怎么办?

1 个答案:

答案 0 :(得分:2)

您没有将ToPagedList()的结果分配给变量(因此不会返回IPagedList<PublicReport>,而只返回IEnumerable<PublicReport>)。将您的代码更改为

public ActionResult ListReports(int? page)
{
    var pageNumber = page ?? 1;     
    var listOfReports = db.PublicReport.OrderByDescending(d => d.CreatedDate).Where(c => c.CategoryId == 1).ToList();
     var pagedList = listOfReports.ToPagedList(pageNumber, 3); // modify
     return View("ReportList", pagedList ); // modify
 }

另请注意,视图中的模型应为

@model IPagedList<RENJK.Models.PublicReport>

然后就没有必要了。它可以只是

@Html.PagedListPager(Model, page => Url.Action(....`