英語で読む

次の方法で共有


ObjectDataSourceFilteringEventArgs クラス

定義

Filtering コントロールの ObjectDataSource イベントのデータを提供します。

C#
public class ObjectDataSourceFilteringEventArgs : System.ComponentModel.CancelEventArgs
継承
ObjectDataSourceFilteringEventArgs

このセクションには、2 つのコード例が含まれています。 最初のコード例では、コントロールを使用して中間層のビジネス オブジェクトからデータを取得し、コントロールを ObjectDataSource 使用して GridView 結果を表示することで、フィルター処理されたデータを表示する方法を示します。 2 番目のコード例では、最初のコード例で使用される中間層ビジネス オブジェクトの例を示します。

次のコード例では、コントロールを使用して中間層のビジネス オブジェクトからデータを取得し、コントロールを ObjectDataSource 使用して GridView 結果を表示することで、フィルター処理されたデータを表示する方法を示します。 コントロールはObjectDataSource、データを取得するメソッドが または DataTable オブジェクトとして取得した場合にのみ、データをDataSetフィルター処理できます。 このため、 プロパティはSelectMethod、 または DataTable オブジェクトとしてデータを取得するビジネス オブジェクト メソッドをDataSet識別します。

このコード例は、コントロール、コントロール、GridViewコントロール、ObjectDataSourceおよび [送信] ボタンで構成されていますTextBox。 既定では、 TextBox コントロールには Northwind Traders の従業員の 1 人の名前が設定されます。 コントロールには GridView 、 の名前で識別される従業員に関する情報が TextBox表示されます。 別の従業員のデータを取得するには、コントロールに TextBox 従業員の氏名を入力し、[ 送信 ] ボタンをクリックします。

プロパティは FilterExpression 、 プロパティで指定されたメソッドによって取得されるデータをフィルター処理するために使用される式を SelectMethod 指定します。 コレクションに含まれるパラメーターに対して評価されるパラメーター プレースホルダーを FilterParameters 使用します。 この例では、パラメーターの型はスペースを含む文字列型であるため、パラメーター プレースホルダーは単一引用符 (') で囲まれています。 パラメーターの型が数値または日付の場合、引用符は必要ありません。 コレクションには FilterParameters 、1 つのパラメーター (コントロールに FormParameter バインドされているオブジェクト) が TextBox 含まれています。

コントロールに TextBox 名前が指定されていない場合は、検索が成功するように新しいパラメーターがコレクションに追加 ParameterValues されます。

重要

この例には、潜在的なセキュリティ上の脅威であるユーザー入力を受け入れるテキスト ボックスが含まれています。 既定では、ASP.NET Web ページによって、ユーザー入力にスクリプトまたは HTML 要素が含まれていないかどうかが検証されます。 詳細については、「スクリプトによる攻略の概要」を参照してください。

ASP.NET (C#)
<%@ Register TagPrefix="aspSample" Namespace="Samples.AspNet.CS" Assembly="Samples.AspNet.CS" %>
<%@ Page language="c#" %>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
    "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<script runat="server">

    protected void ObjectDataSource1_Filtering(object sender, ObjectDataSourceFilteringEventArgs e)
    {
        if (Textbox1.Text == "")
        {
            e.ParameterValues.Clear();
            e.ParameterValues.Add("FullName", "Nancy Davolio");
        }
    }
</script>

<html xmlns="http://www.w3.org/1999/xhtml" >
  <head>
    <title>ObjectDataSource - C# Example</title>
  </head>
  <body>
    <form id="Form1" method="post" runat="server">

        <p>Show all users with the following name.</p>

        <asp:textbox id="Textbox1" runat="server" text="Nancy Davolio" />

        <asp:gridview
          id="GridView1"
          runat="server"
          datasourceid="ObjectDataSource1"
          autogeneratecolumns="False">
          <columns>
            <asp:boundfield headertext="ID" datafield="EmpID" />
            <asp:boundfield headertext="Name" datafield="FullName" />
            <asp:boundfield headertext="Street Address" datafield="Address" />
          </columns>
        </asp:gridview>

        <!-- Security Note: The ObjectDataSource uses a FormParameter,
             Security Note: which does not perform validation of input from the client. -->

        <asp:objectdatasource
          id="ObjectDataSource1"
          runat="server"
          selectmethod="GetAllEmployeesAsDataSet"
          typename="Samples.AspNet.CS.EmployeeLogic"
          filterexpression="FullName='{0}'" OnFiltering="ObjectDataSource1_Filtering">
            <filterparameters>
              <asp:formparameter name="FullName" formfield="Textbox1" defaultvalue="Nancy Davolio" />
            </filterparameters>
        </asp:objectdatasource>

        <p><asp:button id="Button1" runat="server" text="Search" /></p>

    </form>
  </body>
</html>

次のコード例では、前のコード例で使用する中間層ビジネス オブジェクトの例を示します。 このコード例は、 と NorthwindEmployeeの 2 つの基本クラスEmployeeLogicで構成されています。 クラスは EmployeeLogic ビジネス ロジックを NorthwindEmployee カプセル化し、クラスは、データ層からデータを読み込んで永続化するために必要な基本的な機能のみを含むモデル クラスです。 わかりやすくするために、 クラスは EmployeeLogic 、データ層からデータを取得するのではなく、静的なデータ セットを作成します。 完全な作業例を作成するには、これらのクラスをコンパイルして、提供されている Web フォームのコード例と共に使用する必要があります。

C#
namespace Samples.AspNet.CS {

using System;
using System.Collections;
using System.Data;
using System.Web.UI.WebControls;
  //
  // EmployeeLogic is a stateless business object that encapsulates 
  // the operations you can perform on a NorthwindEmployee object.
  //
  public class EmployeeLogic {

    // Returns a collection of NorthwindEmployee objects.
    public static ICollection GetAllEmployees () {
      ArrayList data = new ArrayList();
           
      data.Add(new NorthwindEmployee(1,"Nancy","Davolio","507 - 20th Ave. E. Apt. 2A"));
      data.Add(new NorthwindEmployee(2,"Andrew","Fuller","908 W. Capital Way"));
      data.Add(new NorthwindEmployee(3,"Janet","Leverling","722 Moss Bay Blvd."));
      data.Add(new NorthwindEmployee(4,"Margaret","Peacock","4110 Old Redmond Rd."));
      data.Add(new NorthwindEmployee(5,"Steven","Buchanan","14 Garrett Hill"));
      data.Add(new NorthwindEmployee(6,"Michael","Suyama","Coventry House Miner Rd."));
      data.Add(new NorthwindEmployee(7,"Robert","King","Edgeham Hollow Winchester Way"));
      
      return data;
    }
    
    public static NorthwindEmployee GetEmployee(object anID) {
      ArrayList data = GetAllEmployees() as ArrayList;     
      int empID = Int32.Parse(anID.ToString());      
      return data[empID] as NorthwindEmployee;
    }

    // 
    // To support basic filtering, the employees cannot
    // be returned as an array of objects, rather as a 
    // DataSet of the raw data values. 
    public static DataSet GetAllEmployeesAsDataSet () {
      ICollection employees = GetAllEmployees();
      
      DataSet ds = new DataSet("Table");
      
      // Create the schema of the DataTable.
      DataTable dt = new DataTable();
      DataColumn dc;
      dc = new DataColumn("EmpID",   typeof(int));    dt.Columns.Add(dc);
      dc = new DataColumn("FullName",typeof(string)); dt.Columns.Add(dc);
      dc = new DataColumn("Address", typeof(string)); dt.Columns.Add(dc);
      
      // Add rows to the DataTable.
      DataRow row;
            
      foreach (NorthwindEmployee ne in employees) {                
        row = dt.NewRow();
        row["EmpID"]    = ne.EmpID;
        row["FullName"] = ne.FullName;
        row["Address"]  = ne.Address;
        dt.Rows.Add(row);
      } 
      // Add the complete DataTable to the DataSet.
      ds.Tables.Add(dt);
      
      return ds;
    }    
  }

  public class NorthwindEmployee {

    public NorthwindEmployee (int anID, 
                              string aFirstName,
                              string aLastName,
                              string anAddress) {
      ID = anID;
      firstName = aFirstName;
      lastName = aLastName;   
      address = anAddress;
    }

    private object ID;
    public string EmpID {
      get { return ID.ToString();  }
    }

    private string lastName;
    public string LastName {
      get { return lastName; }
      set { lastName = value; }
    }

    private string firstName;
    public string FirstName {
      get { return firstName; }
      set { firstName = value;  }
    }
    
    public string FullName {
      get { return FirstName  + " " +  LastName; }
    }
    
    private string address;
    public string Address {
      get { return address; }
      set { address = value;  }
    }    
  }
}

注釈

クラスは ObjectDataSourceFilteringEventArgs 、コントロールのイベント ハンドラーにデータを Filtering 渡すために使用されます ObjectDataSource 。 プロパティは ParameterValues 、フィルター処理操作を実行する前に、フィルター パラメーターの値にアクセスできます。 メソッドをSelect取り消すには、 の ObjectDataSourceFilteringEventArgs プロパティを Canceltrue設定します。

コンストラクター

ObjectDataSourceFilteringEventArgs(IOrderedDictionary)

指定されたオブジェクトを使用して、ObjectDataSourceFilteringEventArgs クラスの新しいインスタンスを初期化します。

プロパティ

Cancel

イベントをキャンセルするかどうかを示す値を取得または設定します。

(継承元 CancelEventArgs)
ParameterValues

ObjectDataSource クラスの Parameter オブジェクトへのアクセスを提供する IOrderedDictionary インターフェイスを取得します。

メソッド

Equals(Object)

指定されたオブジェクトが現在のオブジェクトと等しいかどうかを判断します。

(継承元 Object)
GetHashCode()

既定のハッシュ関数として機能します。

(継承元 Object)
GetType()

現在のインスタンスの Type を取得します。

(継承元 Object)
MemberwiseClone()

現在の Object の簡易コピーを作成します。

(継承元 Object)
ToString()

現在のオブジェクトを表す文字列を返します。

(継承元 Object)

適用対象

製品 バージョン
.NET Framework 2.0, 3.0, 3.5, 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1

こちらもご覧ください