ページングのために「1 2 3 4 ...」のみを表示するようにMvcContrib Gridページャーのスタイルを設定することは可能ですか?
2 に答える
0
そのような機能の私の実装があります:
@using MvcContrib.UI.Pager
@model MvcContrib.Pagination.IPagination
@{
string action = ViewContext.Controller.ValueProvider.GetValue("action").RawValue.ToString();
string controller = ViewContext.Controller.ValueProvider.GetValue("controller").RawValue.ToString();
}
@functions
{
public RouteValueDictionary GetRoute(int page)
{
var routeValues = new RouteValueDictionary();
foreach (var key in Context.Request.QueryString.AllKeys.Where(key => key != null))
{
routeValues[key] = Context.Request.QueryString[key];
}
routeValues["page"] = page;
return routeValues;
}
}
<div class="pagination">
<center>
<span class="paginationRight">
@{
int thisPage = Model.PageNumber;
if (Model.HasPreviousPage)
{
for (int i = (5 < Model.PageNumber ? 5 : Model.PageNumber); i >= 1; i--)
{
int page = thisPage - i;
if (page > 0)
{
<text>
@Html.ActionLink(page.ToString(), action, controller, GetRoute(page), null)
</text>
}
}
}
<text> | @Model.PageNumber | </text>
if (Model.HasNextPage)
{
for (int i = 1; i <= (5 < Model.TotalPages - Model.PageNumber ? 5 : Model.TotalPages - Model.PageNumber); i++)
{
int page = thisPage + i;
if (page > 0)
{
<text>
@Html.ActionLink(page.ToString(), action, controller, GetRoute(page), null)
</text>
}
}
}
}
</span>
</center>
</div>
美しくはありませんが、私にとっては非常にうまく機能し、ニーズに合わせて変更するのは非常に簡単です。
于 2012-07-05T17:37:04.840 に答える
0
私が知る限り、そのオプションはそのままでは存在しません。コードプレックスで同じ質問をしましたが、まだ準備ができていないようです:
于 2011-04-08T09:27:09.170 に答える