ObjectDataSource.ObjectCreating イベント

定義

TypeName プロパティで識別されるオブジェクトが作成される前に発生します。

public event System.Web.UI.WebControls.ObjectDataSourceObjectEventHandler ObjectCreating;

イベントの種類

このセクションには、2 つのコード例が含まれています。 最初のコード例では、ビジネス オブジェクトとコントロールで オブジェクトを ObjectDataSource 使用して情報を GridView 表示する方法を示します。 2 番目のコード例では、最初のコード例で使用される中間層ビジネス オブジェクトを提供します。

次のコード例では、ビジネス オブジェクトとコントロールでコントロールを ObjectDataSource 使用して情報を GridView 表示する方法を示します。 Web ページが実行するすべてのデータ操作に対して (時間またはリソースの観点から) 作成するコストが非常に高いビジネス オブジェクトを操作する場合があります。 コストの高いオブジェクトを操作する方法の 1 つは、そのインスタンスを 1 回作成し、そのインスタンスを、すべてのデータ操作に対して作成および破棄するのではなく、後続の操作用にキャッシュすることです。

注意

運用アプリケーションでは、複数の要求が同じインスタンスを同時に使用する場合があります。 そのため、オブジェクトはスレッド セーフな方法で実装する必要があります。

このコード例では、このパターンを示します。 イベントを ObjectCreating 処理して、最初にオブジェクトのキャッシュを確認し、まだキャッシュされていない場合にのみオブジェクトのインスタンスを作成できます。 次に、 イベントを ObjectDisposing 処理して、ビジネス オブジェクトを破棄するのではなく、将来使用するためにキャッシュします。 このコード例では、 CancelEventArgs.Cancel オブジェクトの ObjectDataSourceDisposingEventArgs プロパティを に true 設定して、 ObjectDataSource オブジェクトに対して メソッドを呼び出 Dispose さないよう指示します。

<%@ Import namespace="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">

// Instead of creating and destroying the business object each time, the 
// business object is cached in the ASP.NET Cache.
private void GetEmployeeLogic(object sender, ObjectDataSourceEventArgs e)
{
    // First check to see if an instance of this object already exists in the Cache.
    EmployeeLogic cachedLogic;
    
    cachedLogic = Cache["ExpensiveEmployeeLogicObject"] as EmployeeLogic;
    
    if (null == cachedLogic) {
            cachedLogic = new EmployeeLogic();            
    }
        
    e.ObjectInstance = cachedLogic;     
}

private void ReturnEmployeeLogic(object sender, ObjectDataSourceDisposingEventArgs e)
{    
    // Get the instance of the business object that the ObjectDataSource is working with.
    EmployeeLogic cachedLogic = e.ObjectInstance as EmployeeLogic;        
    
    // Test to determine whether the object already exists in the cache.
    EmployeeLogic temp = Cache["ExpensiveEmployeeLogicObject"] as EmployeeLogic;
    
    if (null == temp) {
        // If it does not yet exist in the Cache, add it.
        Cache.Insert("ExpensiveEmployeeLogicObject", cachedLogic);
    }
    
    // Cancel the event, so that the object will 
    // not be Disposed if it implements IDisposable.
    e.Cancel = true;
}
</script>

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

        <asp:gridview
          id="GridView1"
          runat="server"          
          datasourceid="ObjectDataSource1">
        </asp:gridview>

        <asp:objectdatasource 
          id="ObjectDataSource1"
          runat="server"          
          selectmethod="GetCreateTime"          
          typename="Samples.AspNet.CS.EmployeeLogic"
          onobjectcreating="GetEmployeeLogic"
          onobjectdisposing="ReturnEmployeeLogic" >
        </asp:objectdatasource>        

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

次のコード例では、前のコード例で使用する中間層ビジネス オブジェクトの例を示します。 このコード例は、 クラスによって定義される基本的なビジネス オブジェクトで EmployeeLogic 構成されています。これは、ビジネス ロジックをカプセル化するステートフル クラスです。 完全な動作例については、このコードをライブラリとしてコンパイルし、ASP.NET ページ (.aspx ファイル) からこれらのクラスを使用する必要があります。

namespace Samples.AspNet.CS {

using System;
using System.Collections;
using System.Web.UI;
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 {

    public EmployeeLogic () : this(DateTime.Now) {        
    }
    
    public EmployeeLogic (DateTime creationTime) { 
        _creationTime = creationTime;
    }

    private DateTime _creationTime;
    
    // Returns a collection of NorthwindEmployee objects.
    public ICollection GetCreateTime () {
      ArrayList al = new ArrayList();
      
      // Returns creation time for this example.      
      al.Add("The business object that you are using was created at " + _creationTime);
      
      return al;
    }
  }
}

注釈

データ操作を実行するために識別されるメソッドが static (Shared Visual Basic の場合) の場合、 ObjectCreating イベントと ObjectCreated イベントは発生しません。

コントロールは ObjectDataSource 、ビジネス オブジェクトのパラメーターなしのコンストラクターを自動的に呼び出し、リフレクションを使用してインスタンスを作成します。 イベントを処理して別のObjectCreatingコンストラクターを明示的に呼び出し、その結果のオブジェクトのインスタンスを関連付けられたObjectDataSourceEventArgsオブジェクトの プロパティにObjectInstance設定します。

イベントを処理する方法の詳細については、次を参照してください。処理とイベントの発生します。

適用対象

製品 バージョン
.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

こちらもご覧ください