PagedList MVC中的分页问题

时间:2015-08-31 12:21:04

标签: asp.net asp.net-mvc pagedlist

我正在使用MVC PagedList 来处理项目中的分页。一切正常,但在我的控制器中,我必须用“1”(默认页码)初始化 pageNumber 参数。问题是第1页上的蓝色激活按钮仍然存在,无论您单击哪个页面按钮链接。此外,按钮也缺少actionLink。

我将搜索分页集成在一起,如控制器代码中所示。

Paged List

public PartialViewResult List_Items(string keyword, int? page)
{
    var newlists = from s in db.TrMs
                   orderby s.S1
                   select s;

    int pageNumber = (page ?? 1);
    int pageSize = 10;
    var data = newlists.Where(f => f.S1.ToString().Contains(keyword) && f.S100 == vt).ToPagedList(pageNumber, pageSize);
    return PartialView(data);
}

以下是视图

中为PagedList生成的 Html
<div class="pagination-container">
    <ul class="pagination">
        <li class="active">
            <a>1</a>
        </li>
        <li>
            <a data-ajax="true" data-ajax-method="GET" data-ajax-mode="replace" data-ajax-update="#searchResult" href="/TrM/Search_Items?keyword=&amp;page=2">2</a>
        </li>
        <li>
            <a data-ajax="true" data-ajax-method="GET" data-ajax-mode="replace" data-ajax-update="#searchResult" href="/TrM/Search_Items?keyword=&amp;page=3">3</a>
        </li>
        <li>
            <a data-ajax="true" data-ajax-method="GET" data-ajax-mode="replace" data-ajax-update="#searchResult" href="/TrM/Search_Items?keyword=&amp;page=4">4</a>
        </li>
        <li class="PagedList-skipToNext">
            <a data-ajax="true" data-ajax-method="GET" data-ajax-mode="replace" data-ajax-update="#searchResult" href="/TrM/Search_Items?keyword=&amp;page=2" rel="next">»</a>
        </li>
    </ul>
</div>

以下是我使用分页助手的方法。

Page @(Model.PageCount < Model.PageNumber ? 0 : Model.PageNumber) of @Model.PageCount
@Html.PagedListPager(Model, page => Url.Action("List_Items", "TrM", new {keyword="", page }), PagedListRenderOptions.EnableUnobtrusiveAjaxReplacing(new AjaxOptions() { HttpMethod = "GET", UpdateTargetId = "searchResult" }))

1 个答案:

答案 0 :(得分:2)

您的分页控件很可能位于 searchResult 容器之外。当您单击页面时,您正在替换表而不是分页控件。将您的分页控件移到 searchResult 容器中!

希望这有帮助。