SHOEISHA iD

※旧SEメンバーシップ会員の方は、同じ登録情報(メールアドレス&パスワード)でログインいただけます

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

Scott Guthrie氏 Blog翻訳

Webフォームモデルバインディング パート2:データのフィルタリング (ASP.NET vNextシリーズ)

連載:ScottGu's Blog翻訳


  • X ポスト
  • このエントリーをはてなブックマークに追加

 本稿は、Scott Guthrie氏のブログを、氏の許可を得て、翻訳、転載したものです。米Microsoft社の副社長で、ASP.NETやSilverlightの開発チームを統率する氏のブログでは、次期製品を含む最新の技術をいち早く紹介しています。

  • X ポスト
  • このエントリーをはてなブックマークに追加

 原典:Web Forms Model Binding Part 2: Filtering Data (ASP.NET vNext Series)

 ASP.NET vNextのブログ投稿シリーズで、今回は4回目になります。

 vNextリリースの.NETおよびVisual Studioには、新機能が非常に多く含まれています。ASP.NET vNextでは、WebフォームとMVC、またそのどちらもの基盤となっているASP.NETコアも含め、非常に素晴らしい改善点が多く見られます。

 本日の投稿は、Webフォームの新しいモデルバインディングサポートに関する、3つの投稿のうちの2つ目になります。モデルバインディングは、ASP.NET Webフォームにある既存のデータバインディングシステムの拡張で、コードにフォーカスしたデータアクセスの枠組みを提供します。ASP.NET MVCで最初に導入したモデルバインディング概念の大部分を利用し、Webフォームのサーバーコントロールモデルとうまく統合できます。

 初回のモデルバインディング投稿では、データを選択する基本事項を説明しました。本日の投稿では、データアクセスに対してコードにフォーカスした方法を取り、ユーザの入力に応じて、選択するデータにフィルターをかける方法を見ていきます。クエリ文字列の入力値とドロップダウンリストの値の両方を使って、このフィルタリングの方法を紹介します。

はじめに

 まず、<asp:GridView>コントロールをページに追加し、NorthwindのProductsテーブルからいくつかデータを表示するために、モデルバインディングの構成をします。以下のGridViewでは、SelectMethodプロパティにGetProductsメソッドが設定されています。これにより、コードビハインドファイル内でGetProductsメソッドが呼び出されますが、そこではバインドするProductsを簡単に返すために、Entity Framework コードファーストが使用されています。

<asp:GridView ID="productsGrid" SelectMethod="GetProducts" DataKeyNames="ProductID"
    AllowPaging="true" AllowSorting="true" AutoGenerateColumns="false" runat="server">
    <Columns>
        <asp:BoundField DataField="ProductID" HeaderText="ID" />
        <asp:BoundField DataField="ProductName" HeaderText="Name" SortExpression="ProductName" />
        <asp:BoundField DataField="UnitPrice" HeaderText="Unit Price" SortExpression="UnitPrice" />
        <asp:BoundField DataField="UnitsInStock" HeaderText="# in Stock" SortExpression="UnitsInStock" />
    </Columns>
</asp:GridView>

 以下は(GetProductsメソッドが含まれた)コードビハインドファイルの様子です。

public partial class Products : Page
{
    Northwind db = new Northwind();
    public IQueryable<Product> GetProducts()
    {
        return db.Products;
    }
}

 このページを実行すると、予想していた製品データの含まれた表が生成されます。

 GetProductsメソッドから、IQueryable<Product>を返しているので、ソートやページングは自動的に行われます(これはデータベースで行われ、必要な10個だけの結果が中間層に返されるので効率的です)。

会員登録無料すると、続きをお読みいただけます

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

次のページ
クエリ文字列パラメータを使用したフィルタリング

この記事は参考になりましたか?

  • X ポスト
  • このエントリーをはてなブックマークに追加
Scott Guthrie氏 Blog翻訳連載記事一覧

もっと読む

この記事の著者

WINGSプロジェクト Chica(チカ)

WINGSプロジェクトについて>有限会社 WINGSプロジェクトが運営する、テクニカル執筆コミュニティ(代表 山田祥寛)。主にWeb開発分野の書籍/記事執筆、翻訳、講演等を幅広く手がける。2018年11月時点での登録メンバは55名で、現在も執筆メンバを募集中。興味のある方は、どしどし応募頂きたい。著書記事多数。 RSS X: @WingsPro_info(公式)、@WingsPro_info/wings(メンバーリスト) Facebook

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

Scott Guthrie(Scott Guthrie)

※プロフィールは、執筆時点、または直近の記事の寄稿時点での内容です

この記事は参考になりましたか?

この記事をシェア

  • X ポスト
  • このエントリーをはてなブックマークに追加
CodeZine(コードジン)
https://codezine.jp/article/detail/6289 2011/12/05 11:31

おすすめ

アクセスランキング

アクセスランキング

イベント

CodeZine編集部では、現場で活躍するデベロッパーをスターにするためのカンファレンス「Developers Summit」や、エンジニアの生きざまをブーストするためのイベント「Developers Boost」など、さまざまなカンファレンスを企画・運営しています。

新規会員登録無料のご案内

  • ・全ての過去記事が閲覧できます
  • ・会員限定メルマガを受信できます

メールバックナンバー

アクセスランキング

アクセスランキング