【问题标题】:Add paging to razor view in asp.net core在 asp.net 核心中将分页添加到剃刀视图
【发布时间】:2018-04-29 16:42:20
【问题描述】:

我一直在关注我在 microsoft 找到的一篇关于如何在 c# 中将分页添加到项目的简单文章。这是文章:https://docs.microsoft.com/en-us/aspnet/core/data/ef-mvc/sort-filter-page?view=aspnetcore-2.1

现在在阅读这篇文章时,当我想将数据传递给视图时,最后遇到了一个问题。让我分享一些我的代码,以便你们更好地理解它:

我从 microsft 获得的分页列表:

    public class PaginatedList<T> : List<T>
    {
        public int PageIndex { get; private set; }
        public int TotalPages { get; private set; }

        public PaginatedList(List<T> items, int count, int pageIndex, int pageSize)
        {
            PageIndex = pageIndex;
            TotalPages = (int)Math.Ceiling(count / (double)pageSize);

            this.AddRange(items);
        }

        public bool HasPreviousPage
        {
            get
            {
                return (PageIndex > 1);
            }
        }

        public bool HasNextPage
        {
            get
            {
                return (PageIndex < TotalPages);
            }
        }

        public static async Task<PaginatedList<T>> CreateAsync(IQueryable<T> source, int pageIndex, int pageSize)
        {
            var count = await source.CountAsync();
            var items = await source.Skip((pageIndex - 1) * pageSize).Take(pageSize).ToListAsync();
            return new PaginatedList<T>(items, count, pageIndex, pageSize);
        }
    }

我使用的控制器上的方法:

    [HttpGet("search/{option?}/{search}")]
    public  IActionResult GetSearchData(string option, string search, int? page, string currentFilter)
    {
        if (search != null)
        {
            page = 1;
        }
        else
        {
            search = currentFilter;
        }
        SearchViewModel data = new SearchViewModel();

        var searchArticle = Mapper.Map<IEnumerable<SearchDataItemViewModel>>(_unitOfWork.Articles.GetByString(search));
        data.SearchArticle = searchArticle;

        var searchArticle2 = Mapper.Map<IEnumerable<SearchDataItemViewModel>>(_unitOfWork.Articles2.GetByString(search));
        data.SearchArticle2 = searchArticle2;

        var searchArticle3 = Mapper.Map<IEnumerable<SearchDataItemViewModel>>(_unitOfWork.Articles3.GetByString(search));
        data.SearchArticle3 = searchArticle3;

        var searchArticle4 = Mapper.Map<IEnumerable<SearchDataItemViewModel>>(_unitOfWork.Articles4.GetByString(search));
        data.SearchArticle4 = searchArticle4;

        int pageSize = 10;
        //return View("Search", Helpers.PaginatedList<SearchDataItemViewModel>.CreateAsync(data, page ?? 1, pageSize));
        //this is where I got an error
    }

我得到的错误是:

参数 1:无法从 'Website.ViewModels.SearchViewModel' 转换为 System.Linq.IQueryable

这也是我的一个查询示例:

    public IEnumerable<Article2> GetByString(string word)
    {
        IEnumerable<Article2> article2 = _appContext.Article2
            .Include(t => t.ParentPage)
            .Where(t => t.Status == RecordStatus.Enabled && (t.Name.Contains(word) || t.Description.Contains(word)));
        return article2;
    } 

我实际上理解这意味着什么,但是如何在视图上传递“数据”变量以便我可以使用它?
我有点卡在这里,所以任何帮助的人都会受到高度赞赏。至少给我指出正确的方向之类的。

感谢您的时间!!!

【问题讨论】:

  • 不确定您为什么发布帮助,异常消息一点也不含糊。仅通过阅读您的异常消息,我就可以得出您发送到视图的类与视图期望的类不匹配
  • 你错了@ErikPhilips。这与我发送到视图的课程无关。无论如何,我并不完全了解如何更改我的代码以使其正常工作,这就是我发布帮助的原因。
  • 正确,逻辑仍然合理,您正在尝试为不同的类型变量/成员赋值。
  • 是的,我已经明白了,问题在于我应该如何完全修改代码,以便将数据变量传递给视图。无论如何,我已经发布了关于我如何实现这一目标的答案。

标签: c# entity-framework asp.net-core linq-to-entities entity-framework-core


【解决方案1】:

在您的 Linq 语句中,您缺少指定如何选择以便它返回一个 Linq 对象;而不是 Article2 对象;应该是这样的:

  public IEnumerable<Article2> GetByString(string word)
{
    IEnumerable<Article2> article2 = _appContext.Article2
        .Include(t => t.ParentPage)
        .Where(t => t.Status == RecordStatus.Enabled && (t.Name.Contains(word) || t.Description.Contains(word))).ToList();
    return article2;
} 

添加ToList()

【讨论】:

  • 不,@john-nyingi 并非如此。我猜问题出在CreateAsync 任务的分页列表类中。但我无法围绕它。
  • 我已经尝试过了,但它不起作用:/ @john-nyingi。还有其他想法吗?或者任何链接我可以得到一个关于如何添加分页的例子?
【解决方案2】:

解决了。我所做的就是以这种方式修改控制器。

[HttpGet("search/{option?}/{search}")]
public  IActionResult GetSearchData(string option, string search, int? page, string currentFilter)
{
    if (search != null)
    {
        page = 1;
    }
    else
    {
        search = currentFilter;
    }
    SearchViewModel data = new SearchViewModel();
    int pageSize = 10;
    IEnumerable<SearchDataItemViewModel> searchArticle = Mapper.Map<IEnumerable<SearchDataItemViewModel>>(_unitOfWork.Articles.GetByString(search));
        var searchArticleP = Helpers.PaginatedList<SearchDataItemViewModel>.CreateAsync(searchArticle, page ?? 1, pageSize);
        data.SearchArticle = searchArticleP;

    IEnumerable<SearchDataItemViewModel> searchArticle2 = Mapper.Map<IEnumerable<SearchDataItemViewModel>>(_unitOfWork.Articles2.GetByString(search));
        var searchArticleP2 = Helpers.PaginatedList<SearchDataItemViewModel>.CreateAsync(searchArticle2, page ?? 1, pageSize);
        data.SearchArticle2 = searchArticleP2;
    return View("Search", data));
}

【讨论】:

    猜你喜欢
    • 2013-09-28
    • 2018-04-24
    • 1970-01-01
    • 2021-01-22
    • 1970-01-01
    • 2019-06-13
    • 2020-11-09
    • 2019-04-09
    • 2021-01-05
    相关资源
    最近更新 更多