Stackoverflow ページャーによく似た、ASP.NET で適切なページング コントロールを探しています。誰でもお勧めできますか?
Postback も使用せず、カスタマイズ可能なクエリ文字列のみを使用する方がよいでしょう。
自分で巻くのはとても簡単です。スタック オーバーフロー ページャーに基づいて、2 つのプロパティを持つ単純なユーザー コントロールを作成しました...
選択されたページは、クエリ文字列を読み取ることによって決定されます。最大の課題は、新しいページ番号で URL を変更することでした。このメソッドは、クエリ文字列パラメーター 'p' を使用して、表示するページを指定します...
string getLink(int toPage)
{
NameValueCollection query = HttpUtility.ParseQueryString(Request.Url.Query);
query["p"] = toPage.ToString();
string url = Request.Path;
for(int i = 0; i < query.Count; i++)
{
url += string.Format("{0}{1}={2}",
i == 0 ? "?" : "&",
query.Keys[i],
string.Join(",", query.GetValues(i)));
}
return url;
}
表示するページ番号の範囲を決定する簡単な式...
int min = Math.Min(Math.Max(0, Selected - (PageLinksToShow / 2)), Math.Max(0, PageCount - PageLinksToShow + 1));
int max = Math.Min(PageCount, min + PageLinksToShow);
次に、各リンクは次のようなものを使用して生成されます(最小値と最大値は、作成するページリンクの範囲を指定します)...
for (int i = min; i <= max; i++)
{
HyperLink btn = new HyperLink();
btn.Text = (i + 1).ToString();
btn.NavigateUrl = getLink(i);
btn.CssClass = "pageNumbers" + (Selected == i ? " current" : string.Empty);
this.Controls.Add(btn);
}
「前へ」(および「次へ」) ボタンを作成することもできます...
HyperLink previous = new HyperLink();
previous.Text = "Previous";
previous.NavigateUrl = getLink(Selected - 1);
最初と最後のボタンは簡単です...
HyperLink previous = new HyperLink();
previous.Text = "1";
first.NavigateUrl = getLink(0);
「...」をいつ表示するかを決定する際に、リンク範囲が最初または最後のページの隣にない場合は、リテラル コントロールを表示します...
if (min > 0)
{
Literal spacer = new Literal();
spacer.Text = "…";
this.Controls.Add(spacer);
}
「max < PageCount」についても上記と同じことを行います。
このコードはすべて、CreateChildControls のオーバーライド メソッドに入れられます。
もっと多くの答えを期待していましたが、多くの人が自分で作っているようです. 私は、codeproject.comでかなり頻繁に維持されている適切なものを見つけました。
これは、stackoverflow.com のものとまったく同じではありません。さまざまな出力オプションを備えたまともなオープン ソース コントロールがあればいいのですが。
私は DevExpress と Telerik ページ コントロールを使用してきましたが、DevExpress ページャーを好みます。DevExpress ページャーがクエリ文字列を直接操作できるかどうかはわかりませんが、非常に柔軟であるため、そうでない場合は驚くでしょう。ダウンロード後の既存のページ間のページングに関しては、すべてクライアント上に置くことができます。サーバーへの移動が必要な場合、コントロールは完全に AJAX を備えています。www.devexpress.com で検索を開始してから、www.Telerik.com もチェックすることをお勧めします (これも AJAX を備えています)。
コントロールではありませんが、これは DB レベルでページングを実装する方法です: SQL Server 2005 ページング