Как сделать пейджинг в сетке MVC? - PullRequest
0 голосов
/ 18 ноября 2009

Любые предложения о том, как сделать пейджинг в сетке mvc, самым простым способом? Пожалуйста, укажите мне пример кода, если таковой имеется

1 Ответ

2 голосов
/ 18 ноября 2009

Ритц,

Я думаю, что этот вопрос уже задавался, но вот вопрос, на который я ссылаюсь: Пейджинг и сортировка сеток с ASP.Net MVC

Кроме того, это очень краткое руководство о том, как это сделать:
http://xlib.wordpress.com/2009/06/29/asp-net-mvc-grid-%E2%80%93-part-2-paging/

Некоторые фрагменты из вышеуказанной ссылки:

Используйте это, чтобы получить селектор на вашей странице, позволяющий пользователю определять количество строк, отображаемых на странице:

<%= Html.DropDownList("pageSize", CustomerController.PageSizeSelectList(), new { onchange = "onPageSizeChange()" })%> rows per page

Затем в пользовательском контроллере страницы напишите этот код:

public static SelectList PageSizeSelectList()
{
    var pageSizes = new List {"1", "2", "5", "10", "100"};
    return new SelectList(pageSizes, "Value");
}

Теперь добавьте JavaScript на страницу:

//Set hidden variable to go to next/prev/last/first page and submit the form
function goToPage(pageIndex) {
    $("#currentPage").val(pageIndex);
    $("#gridAction").val("CurrentPageChanged");

    submitForm();
}

//Set action performed in hidden variable. When PageSize changes - PageIndex needs to be
//reset to 1. This logic will go on the server side.
function onPageSizeChange(pageIndex) {
    $("#gridAction").val("PageSizeChanged");
    submitForm();
}

function submitForm() {
    var form = $("#grid").parents("form:first");
    form.submit();
}

Затем обновите контроллер страницы для выполнения подкачки:

[AcceptVerbs(HttpVerbs.Post)]
public ActionResult List(int currentPage, int pageSize, string gridAction)
{
        //Do logic depending on what action was performed
    if (gridAction == "PageSizeChanged")
        currentPage = 1;

        //Check if there are no results.  In this case return empty list.
    IQueryable query = _customerService.GetQueryable();
    int totalRows = query.Count();
    if (totalRows==0)
        return View(new List());

    int totalPages = (int)Math.Ceiling((double)totalRows / (double)pageSize);
    if (totalPages != 1)
    {
        //use LINQ to perform paging
        query = query.Skip((currentPage - 1) * pageSize)
                        .Take(pageSize);
    }

        //Update ViewData collection to display pager stats and pager controls
    UpdatePagerViewData(totalPages, totalRows, currentPage, pageSize);

    List customers = query.ToList();
    return View(customers);
}

Надеюсь, это поможет,

Спасибо!

...