1

我试图找出在 asp.net MVC 中使用 ViewModel 实现 pagedlist 的正确方法。

假设我有以下 PagedClientViewModel:

public class PagedClientViewModel
{
    public PagedList.IPagedList<ClientViewModel> Clients { get; set; }
}

public class ClientViewModel
{
    public string ClientNumber { get; set; }
    public string ClientName { get; set; }       
}

我的观点将引用模型如下:

@model PagedClientViewModel

并且操作方法看起来像这样:

    public ActionResult Index(int? page)
    {
        var pageNumber = page ?? 1;

        var clients = GetAllClients();

        var onePageOfClients = clients.ToPagedList(pageNumber, 25);

        PagedClientViewModel model = new PagedClientViewModel();

        var clientViewModels = new List<ClientViewModel>();

        foreach (var client in clients)
        {
            ClientViewModel clientVM = new ClientViewModel
            {
                ClientName = client.CLIENTNAME,
                ClientNumber = client.CLIENTNO,         
            };
            clientViewModels.Add(clientVM);
        }                    

        model.Clients = //how do I add the clientViewModels to the PagedList<ClientViewModel>?

        return View(model);
    }

在创建视图模型时,我不想从数据库中迭代整个客户端记录列表 - 我是否通过使用包含分页列表的视图模型使事情变得过于复杂?我不想使用 ViewBag!

我的 ViewModel 应该是什么样的?

4

3 回答 3

3

通过使用答案的组合,它可以很好地工作:

    public ActionResult Index(PagedClientViewModel model)
    {
        var pageIndex = model.Page ?? 1;
        var clients = from client in GetAllClients() orderby client.CLIENTNUMBER
                      select new ClientViewModel
                          {
                              ClientName = client.CLIENTNAME,
                              ClientNumber = client.CLIENTNO

                          };        

        model.Clients = clients.ToPagedList(pageIndex, 25);

        return View(model);
    }


public class PagedClientViewModel
{
    public int? Page { get; set; }
    public PagedList.IPagedList<ClientViewModel> Clients { get; set; }
}

public class ClientViewModel
{
    public string ClientNumber { get; set; }
    public string ClientName { get; set; }       
}
于 2012-12-11T08:02:15.980 回答
2

您应该更改调用以检索数据以包含页面参数并在数据库中进行过滤。这样,您只需要从数据库中返回您需要的数据。

var clients = GetClients(page);

此外,如果您不想遍历返回的客户端(您似乎不需要在这里),只需将返回的列表直接设置为您的 ViewModel。像这样的东西会起作用。确保更新 ViewModel,以便model.Clients正确键入。

var clients = GetClients(page);

model.Clients = clients;
于 2012-12-10T14:55:19.680 回答
2

我会把它简化成这样:

public IEnumerable<ClientViewModel> Clients { get; set; }

model.Clients = from client in GetAllClients().Skip(pageNumber * PageSize).Take(PageSize)
                       select new ClientViewModel
                       {
                           ClientName = client.CLIENTNAME,
                           ClientNumber = client.CLIENTNO,  
                       };
于 2012-12-10T15:44:53.950 回答